Vue3+@antv/g2plot 生成詞云圖的效果
@antv/g2plot 是一個(gè)基于 AntV 的圖表庫(kù)屬于antv庫(kù)的一部分 用于快速創(chuàng)建各種類(lèi)型的圖表 支持折線(xiàn)圖、柱狀圖、餅圖、散點(diǎn)圖等多種圖表類(lèi)型 @antv/g2plot 屬于antv庫(kù)的一部分 g2plot是在g2基礎(chǔ)上封裝的
npm install @antv/g2plot --save
效果
所有值共享一個(gè)顏色并且每次刷新顏色隨機(jī)生成
組件頁(yè)面
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: '山舌魚(yú)'}, {value: 100, name: '羚羊'}, {value: 37, name: '非洲王子'}, {value: 83, name: '麋鹿'}, {value: 60, name: '中華鱘'}, {value: 42, name: '鮪魚(yú)'}, {value: 96, name: '射水魚(yú)'}, {value: 54, name: '果子貍'}, {value: 33, name: '小春魚(yú)'}, {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>
使用頁(yè)面
<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ī)生成
組件頁(yè)面
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)備,為每個(gè)單詞分配隨機(jī)顏色,并確保數(shù)據(jù)有效性 const data = [ { value: 67, name: '紅腹角雉' }, { value: 98, name: '麝牛' }, { value: 97, name: '山舌魚(yú)' }, { value: 100, name: '羚羊' }, { value: 37, name: '非洲王子' }, { value: 83, name: '麋鹿' }, { value: 60, name: '中華鱘' }, { value: 42, name: '鮪魚(yú)' }, { value: 96, name: '射水魚(yú)' }, { value: 54, name: '果子貍' }, { value: 33, name: '小春魚(yú)' }, { 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); // 移除無(wú)效的數(shù)據(jù)項(xiàng) // 創(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>
使用頁(yè)面
<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)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue 獲取到數(shù)據(jù)但卻渲染不到頁(yè)面上的解決方法
這篇文章主要介紹了vue 獲取到數(shù)據(jù)但卻渲染不到頁(yè)面上的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11vue路由傳參頁(yè)面刷新參數(shù)丟失問(wèn)題解決方案
這篇文章主要介紹了vue路由傳參頁(yè)面刷新參數(shù)丟失問(wèn)題解決方案,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-10-10從0到1構(gòu)建vueSSR項(xiàng)目之路由的構(gòu)建
這篇文章主要介紹了從0到1構(gòu)建vueSSR項(xiàng)目之路由的構(gòu)建,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-03-03vue 本地服務(wù)不能被外部IP訪問(wèn)的完美解決方法
這篇文章主要介紹了vue 本地服務(wù)不能被外部IP訪問(wèn)的解決方法,本文通過(guò)代碼講解的非常詳細(xì),需要的朋友可以參考下2018-10-10深入淺出 Vue 系列 -- 數(shù)據(jù)劫持實(shí)現(xiàn)原理
深入淺出 Vue 系列 -- 數(shù)據(jù)劫持實(shí)現(xiàn)原理2019-04-04解決vue無(wú)法加載文件D:\Program Files\nodejs\node_global\vue.ps1,
這篇文章主要給大家介紹了關(guān)于解決vue無(wú)法加載文件D:\Program Files\nodejs\node_global\vue.ps1,因?yàn)樵诖讼到y(tǒng)上禁止運(yùn)行腳本的相關(guān)資料,這個(gè)報(bào)錯(cuò)是由于在系統(tǒng)上禁止運(yùn)行腳本導(dǎo)致的,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01Vue使用自定義指令實(shí)現(xiàn)頁(yè)面底部加水印
本文主要實(shí)現(xiàn)給項(xiàng)目的整個(gè)背景加上自定義水印,可以改變水印的文案和字體顏色等,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06前端單獨(dú)實(shí)現(xiàn)vue動(dòng)態(tài)路由的示例代碼
Vue動(dòng)態(tài)路由權(quán)限涉及根據(jù)用戶(hù)權(quán)限動(dòng)態(tài)生成路由配置,實(shí)現(xiàn)此功能可增強(qiáng)應(yīng)用安全性、靈活性,提升用戶(hù)體驗(yàn)和開(kāi)發(fā)效率,本文就來(lái)介紹一下前端單獨(dú)實(shí)現(xiàn)vue動(dòng)態(tài)路由的示例代碼,感興趣的可以了解一下2024-09-09