在数据可视化场景中,词云图是一种非常直观且吸引人的表现形式,尤其在需要统计词语出现频率或展示关键词权重时,词云图能够以形象化的方式呈现信息。本文将详细介绍如何使用 Vue3
、ECharts
以及 ECharts-WordCloud
插件开发各种类型的词云图,从基础到高级功能,让你掌握词云图的开发技巧。
开发一个基础的词云图:
步骤一: 创建一个Vue3项目
首先,我们需要创建一个 Vue3
项目,推荐使用 Vite
来快速搭建项目环境。可以通过以下命令创建项目:
pnpm create vite vue-echarts --template vue
cd vue-echarts
步骤二: 安装echarts 和echarts-wordcloud
在项目目录下安装 ECharts
和 ECharts-WordCloud
插件:
pnpm i echarts echarts-wordcloud
步骤三: 运行项目
运行以下命令启动开发服务器:
pnpm run dev
步骤四:编写词云图组件WordCloudMap
<template>
<div>
<div class="echarts-wrap" ref="echartWord"></div>
</div>
</template>
<script setup>
import { ref, onMounted, onBeforeUnmount } from 'vue';
import * as echarts from 'echarts';
import 'echarts-wordcloud';
const props = defineProps({
// 词云数据
data: {
type: Array,
required: true,
// 示例:
// [
// { name: 'Vue', value: 1000 },
// { name: 'ECharts', value: 618 },
// // ...
// ]
},
// 词云形状,可以是 'circle', 'cardioid', 'diamond', 'triangle-forward', 'triangle', 'pentagon' 等
shape: {
type: String,
default: 'circle',
},
});
const echartWord = ref(null);
let myChart = null;
const initChart = () => {
if (echartWord.value) {
myChart = echarts.init(echartWord.value);
const option = {
series: [{
type: 'wordCloud',
shape: props.shape,
// 其他形状你可以使用形状路径
// shape: 'circle', // 示例
// 或者自定义路径
gridSize: 2,
sizeRange: [12, 60],
rotationRange: [-90, 90],
rotationStep: 45,
// 字体
textStyle: {
normal: {
color: function () {
return 'rgb(' + [
Math.round(Math.random() * 160),
Math.round(Math.random() * 160),
Math.round(Math.random() * 160)
].join(',') + ')';
}
},
emphasis: {
shadowBlur: 10,
shadowColor: '#333'
}
},
// 设置词云数据
data: props.data
}]
};
myChart.setOption(option);
window.addEventListener('resize', myChart.resize);
}
};
onMounted(() => {
initChart();
});
onBeforeUnmount(() => {
if (myChart) {
window.removeEventListener('resize', myChart.resize);
myChart.dispose();
}
});
</script>
<style lang="scss" scoped>
.echarts-wrap{
width: 1000px;
height: 1000px;
}
</style>
步骤四: 使用词云图组件
在项目中引入并使用 WordCloudMap
组件,传入词云数据和图形类型。
<template>
<div>
<WordCloudMap :data="data" :shape="circle" />
</div>
</template>
<script setup>
import WordCloudMap from '@/components/WordCloudMap/index.vue'
const data = [
{ name: 'Vue', value: 1000 },
{ name: 'ECharts', value: 618 },
{ name: 'JavaScript', value: 438 },
{ name: 'HTML', value: 405 },
{ name: 'CSS', value: 248 },
{ name: 'TypeScript', value: 147 },
{ name: 'Webpack', value: 102 },
{ name: 'Babel', value: 86 },
{ name: 'Node.js', value: 62 },
{ name: 'NPM', value: 38 },
{ name: 'React', value: 300 },
{ name: 'Angular', value: 250 },
{ name: 'Svelte', value: 180 },
{ name: 'Backbone', value: 120 },
{ name: 'Ember', value: 95 },
{ name: 'jQuery', value: 400 },
{ name: 'Bootstrap', value: 350 },
{ name: 'Tailwind', value: 220 },
{ name: 'LESS', value: 110 },
{ name: 'SASS', value: 130 },
{ name: 'Git', value: 500 },
{ name: 'GitHub', value: 450 },
{ name: 'GitLab', value: 200 },
{ name: 'Bitbucket', value: 150 },
{ name: 'Docker', value: 320 },
{ name: 'Kubernetes', value: 280 },
{ name: 'AWS', value: 360 },
{ name: 'Azure', value: 340 },
{ name: 'GCP', value: 290 },
{ name: 'Firebase', value: 210 },
{ name: 'GraphQL', value: 190 },
{ name: 'REST', value: 410 },
{ name: 'API', value: 430 },
{ name: 'SQL', value: 370 },
{ name: 'NoSQL', value: 230 },
{ name: 'MongoDB', value: 260 },
{ name: 'PostgreSQL', value: 240 },
{ name: 'MySQL', value: 310 },
{ name: 'SQLite', value: 170 },
{ name: 'Redis', value: 160 },
{ name: 'Memcached', value: 140 },
{ name: 'Python', value: 520 },
{ name: 'Django', value: 340 },
{ name: 'Flask', value: 280 },
{ name: 'Ruby', value: 200 },
{ name: 'Rails', value: 220 },
{ name: 'Laravel', value: 180 },
{ name: 'PHP', value: 300 },
{ name: 'C#', value: 260 },
{ name: '.NET', value: 250 },
{ name: 'Java', value: 480 },
{ name: 'Spring', value: 220 },
{ name: 'Kotlin', value: 190 },
{ name: 'Swift', value: 210 },
{ name: 'Objective-C', value: 150 },
{ name: 'Go', value: 330 },
{ name: 'Rust', value: 170 },
{ name: 'C++', value: 360 },
{ name: 'C', value: 400 },
{ name: 'Perl', value: 90 },
{ name: 'Scala', value: 130 },
{ name: 'Haskell', value: 80 },
{ name: 'Elixir', value: 70 },
{ name: 'Erlang', value: 60 },
{ name: 'Lua', value: 100 },
{ name: 'Shell', value: 140 },
{ name: 'PowerShell', value: 120 },
{ name: 'Vim', value: 200 },
{ name: 'Emacs', value: 180 },
{ name: 'IntelliJ', value: 250 },
{ name: 'VSCode', value: 500 },
{ name: 'Sublime', value: 160 },
{ name: 'Atom', value: 130 },
{ name: 'WebStorm', value: 140 },
{ name: 'PyCharm', value: 210 },
{ name: 'NetBeans', value: 90 },
{ name: 'Eclipse', value: 100 },
{ name: 'Visual Studio', value: 300 },
{ name: 'Xcode', value: 220 },
{ name: 'Android Studio', value: 180 },
{ name: 'Bootstrap', value: 350 },
{ name: 'Tailwind CSS', value: 200 },
{ name: 'Material UI', value: 190 },
{ name: 'Ant Design', value: 170 },
{ name: 'Bulma', value: 150 },
{ name: 'Foundation', value: 140 },
{ name: 'Semantic UI', value: 130 },
{ name: 'Chakra UI', value: 120 },
{ name: 'Styled Components', value: 110 },
{ name: 'Emotion', value: 100 },
{ name: 'Redux', value: 280 },
{ name: 'MobX', value: 160 },
{ name: 'Vuex', value: 180 },
{ name: 'Pinia', value: 140 },
{ name: 'Nuxt.js', value: 200 },
{ name: 'Next.js', value: 220 },
{ name: 'Gatsby', value: 190 },
{ name: 'Gridsome', value: 80 },
{ name: 'Sapper', value: 60 },
{ name: 'Quasar', value: 50 },
{ name: 'TailwindUI', value: 40 },
{ name: 'Storybook', value: 170 },
{ name: 'Jest', value: 250 },
{ name: 'Mocha', value: 200 },
{ name: 'Chai', value: 150 },
{ name: 'Jasmine', value: 120 },
{ name: 'Cypress', value: 180 },
{ name: 'Puppeteer', value: 160 },
{ name: 'Playwright', value: 140 },
];
</script>
<style scoped>
</style>
通过以上步骤,一个基础的词云图就完成了。
查看项目运行结果
可以看到一个词云图就开发完成了。有几个重要的参数配置
词云图参数解释
1. shape
配置词云图的形状, 支持值包括 circle, cardioid, diamond, triangle-forward, triangle,
等 。 以triangle
为例 ,看下效果:
可以看到词云图就变成了一个三角形。其他形状可以自行去尝试。
2. gridSize
控制词语在图中的紧密程度。值越大,词语之间的距离越大。比如现在我们将2改成20,查看效果
可以看到词语之间的举例变稀松了许多。
3. sizeRange
设置字体大小的范围,格式为 [最小值, 最大值]
。
现在我们将sizeRange改成[0, 100]查看效果:
可以看到词语大小的差距变得更加明显了,大的更大,小的更小
4. rotationRange
控制词语的旋转角度范围,格式为 [最小角度, 最大角度]
。
- 示例:设置为
[0, 0]
,所有词语将保持水平。
可以看到词语都不旋转了。
词云图高级功能,自定义形状。
在实际使用中,我们可能需要让词云图的形状更加个性化,比如根据特定的图片轮廓生成词云图。
1. 准备图片
选择一个合适的图片作为词云图的形状模板。可以从 iconfonticonfont(www.iconfont.cn/) 或其他素材网站下载图标。
搜索想要的图形
这里我选择一个空心问号图形:
2.将图片转换为base64
将图片转换为 Base64 格式,可以使用在线工具如 图片转Base64图片转Base64(tool.chinaz.com/tools/imgto…)。
上传刚才下载的图片,在右侧就能看到转换的base64 图片了
3. 修改 WordCloudMap 组件
<template>
<div>
<div class="echarts-wrap" ref="echartWord"></div>
</div>
</template>
<script setup>
import { ref, onMounted, onBeforeUnmount } from 'vue';
import * as echarts from 'echarts';
import 'echarts-wordcloud';
const maskImage = new Image()
maskImage.src = ''
const props = defineProps({
// 词云数据
data: {
type: Array,
required: true,
// 示例:
// [
// { name: 'Vue', value: 1000 },
// { name: 'ECharts', value: 618 },
// // ...
// ]
},
// 词云形状,可以是 'circle', 'cardioid', 'diamond', 'triangle-forward', 'triangle', 'pentagon' 等
shape: {
type: String,
default: 'triangle-forward',
},
});
const echartWord = ref(null);
let myChart = null;
const initChart = () => {
if (echartWord.value) {
myChart = echarts.init(echartWord.value);
const option = {
renderer: 'canvas', // 强制使用 Canvas 渲染器
series: [{
type: 'wordCloud',
shape: props.shape,
// 其他形状你可以使用形状路径
// shape: 'circle', // 示例
// 或者自定义路径
gridSize: 2,
sizeRange: [12, 60],
rotationRange: [-90, 90],
rotationStep: 45,
maskImage: maskImage,
// 字体
textStyle: {
normal: {
color: function () {
return 'rgb(' + [
Math.round(Math.random() * 160),
Math.round(Math.random() * 160),
Math.round(Math.random() * 160)
].join(',') + ')';
}
},
emphasis: {
shadowBlur: 10,
shadowColor: '#333'
}
},
// 设置词云数据
data: props.data
}]
};
maskImage.onload = function () {
myChart.setOption(option, true);
}
window.addEventListener('resize', myChart.resize);
}
};
onMounted(() => {
initChart();
});
onBeforeUnmount(() => {
if (myChart) {
window.removeEventListener('resize', myChart.resize);
myChart.dispose();
}
});
</script>
<style lang="scss" scoped>
.echarts-wrap{
width: 800px;
height: 800px;
}
</style>
主要增加了3行代码:
const maskImage = new Image()
maskImage.src = '...'
maskImage: maskImage,
查看运行效果:
这样一个空心问号词云图就被绘制出来了。
四、总结与扩展
通过本文的讲解,我们已经掌握了如何使用 Vue3、ECharts 和 ECharts-WordCloud 开发各种类型的词云图,包括基础词云图和自定义形状的高级词云图。以下是一些扩展思路:
-
动态数据更新
可以通过 Vue 的响应式数据机制,实现词云图的动态更新。
-
交互功能
利用 ECharts 提供的事件监听功能,为词云图添加点击、鼠标悬浮等交互效果。
-
多种样式组合
结合不同的字体、颜色和动画效果,打造更加炫酷的词云图。
通过不断探索和实践,相信你可以开发出更加丰富多彩的词云图,为数据可视化增添更多亮点!