Vue3+@antv/g2plot 生成詞云圖的效果
更新時間:2024年12月27日 10:56:19 作者:小陽生煎
詞云圖是一種文本可視化技術(shù),用于展示文本數(shù)據(jù)中關(guān)鍵詞的頻次或重要性,文章介紹了如何在Vue3中使用@antv/g2plot生成詞云圖,并解釋了如何共享顏色和隨機(jī)生成顏色的組件,感興趣的朋友一起看看吧
@antv/g2plot 是一個基于 AntV 的圖表庫屬于antv庫的一部分 用于快速創(chuàng)建各種類型的圖表 支持折線圖、柱狀圖、餅圖、散點圖等多種圖表類型 @antv/g2plot 屬于antv庫的一部分 g2plot是在g2基礎(chǔ)上封裝的
npm install @antv/g2plot --save
效果
所有值共享一個顏色并且每次刷新顏色隨機(jī)生成

組件頁面
components-pop.vue
<template>
<div ref="wordCloudContainer" :style="{ width: '100%', height: '400px' }"></div>
</template>
<script>
import { onMounted, ref } from 'vue';
import { WordCloud } from '@antv/g2plot';
export default {
name: 'WordCloudComponent',
setup() {
const wordCloudContainer = ref(null);
onMounted(() => {
const data = [
{value: 67, name: '紅腹角雉'},
{value: 98, name: '麝牛'},
{value: 97, name: '山舌魚'},
{value: 100, name: '羚羊'},
{value: 37, name: '非洲王子'},
{value: 83, name: '麋鹿'},
{value: 60, name: '中華鱘'},
{value: 42, name: '鮪魚'},
{value: 96, name: '射水魚'},
{value: 54, name: '果子貍'},
{value: 33, name: '小春魚'},
{value: 84, name: '水獺'},
{value: 86, name: '刺猬'}
];
const getRandomColor = () => {
const letters = '0123456789ABCDEF';
let color = '#';
for (let i = 0; i < 6; i++) {
color += letters[Math.floor(Math.random() * 16)];
}
return color;
};
const wordCloud = new WordCloud(wordCloudContainer.value, {
data,
wordField: 'name',
weightField: 'value',
sizeRange: [12, 60],
color: getRandomColor(),
shape: 'circle',
wordStyle: {
fontFamily: 'Verdana',
fontWeight: 'bold',
// 可以添加其他文本樣式
},
// 其他配置
});
wordCloud.render();
});
return {
wordCloudContainer,
};
},
};
</script>
<style scoped>
/* 你可以在這里添加組件的樣式 */
</style>使用頁面
<template>
<div id="app">
<WordCloudComponent />
</div>
</template>
<script>
import WordCloudComponent from '@/components/pop.vue';
export default {
name: 'App',
components: {
WordCloudComponent,
},
};
</script>
<style>
/* 你可以在這里添加應(yīng)用的樣式 */
</style>不同值隨機(jī)生成不同顏色并且每次刷新值隨機(jī)生成

組件頁面
components-pop.vue
<template>
<div ref="wordCloudContainer" :style="{ width: '100%', height: '400px' }"></div>
</template>
<script>
import { onMounted, ref } from 'vue';
import { WordCloud } from '@antv/g2plot';
export default {
name: 'WordCloudComponent',
setup() {
const wordCloudContainer = ref(null);
// 隨機(jī)生成顏色的函數(shù)
const getRandomColor = () => {
const letters = '0123456789ABCDEF';
let color = '#';
for (let i = 0; i < 6; i++) {
color += letters[Math.floor(Math.random() * 16)];
}
return color;
};
onMounted(() => {
if (!wordCloudContainer.value) {
console.error('Word cloud container is not available');
return;
}
// 數(shù)據(jù)準(zhǔn)備,為每個單詞分配隨機(jī)顏色,并確保數(shù)據(jù)有效性
const data = [
{ value: 67, name: '紅腹角雉' },
{ value: 98, name: '麝牛' },
{ value: 97, name: '山舌魚' },
{ value: 100, name: '羚羊' },
{ value: 37, name: '非洲王子' },
{ value: 83, name: '麋鹿' },
{ value: 60, name: '中華鱘' },
{ value: 42, name: '鮪魚' },
{ value: 96, name: '射水魚' },
{ value: 54, name: '果子貍' },
{ value: 33, name: '小春魚' },
{ value: 84, name: '水獺' },
{ value: 86, name: '刺猬' }
].map(item => {
if (!item || typeof item !== 'object' || !('name' in item) || !('value' in item)) {
console.error('Invalid data item:', item);
return null;
}
return { ...item, color: getRandomColor() };
}).filter(Boolean); // 移除無效的數(shù)據(jù)項
// 創(chuàng)建詞云圖
const wordCloud = new WordCloud(wordCloudContainer.value, {
data,
wordField: 'name',
weightField: 'value',
sizeRange: [12, 60],
// 直接使用數(shù)據(jù)中的 color 字段作為顏色配置
colorField: 'color', // 指定顏色字段
shape: 'circle',
wordStyle: {
fontFamily: 'Verdana',
fontWeight: 'bold',
},
// 其他配置
});
wordCloud.render();
});
return {
wordCloudContainer,
};
},
};
</script>
<style scoped>
/* 你可以在這里添加組件的樣式 */
</style>使用頁面
<template>
<div id="app">
<WordCloudComponent />
</div>
</template>
<script>
import WordCloudComponent from '@/components/pop.vue';
export default {
name: 'App',
components: {
WordCloudComponent,
},
};
</script>
<style>
/* 你可以在這里添加應(yīng)用的樣式 */
</style>到此這篇關(guān)于Vue3+@antv/g2plot 生成詞云圖的文章就介紹到這了,更多相關(guān)Vue3 @antv/g2plot 詞云圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue 獲取到數(shù)據(jù)但卻渲染不到頁面上的解決方法
這篇文章主要介紹了vue 獲取到數(shù)據(jù)但卻渲染不到頁面上的解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
從0到1構(gòu)建vueSSR項目之路由的構(gòu)建
這篇文章主要介紹了從0到1構(gòu)建vueSSR項目之路由的構(gòu)建,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-03-03
深入淺出 Vue 系列 -- 數(shù)據(jù)劫持實現(xiàn)原理
深入淺出 Vue 系列 -- 數(shù)據(jù)劫持實現(xiàn)原理2019-04-04
解決vue無法加載文件D:\Program Files\nodejs\node_global\vue.ps1,
這篇文章主要給大家介紹了關(guān)于解決vue無法加載文件D:\Program Files\nodejs\node_global\vue.ps1,因為在此系統(tǒng)上禁止運行腳本的相關(guān)資料,這個報錯是由于在系統(tǒng)上禁止運行腳本導(dǎo)致的,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01

