Vue3+@antv/g2plot 生成詞云圖的效果
@antv/g2plot 是一個(gè)基于 AntV 的圖表庫屬于antv庫的一部分 用于快速創(chuàng)建各種類型的圖表 支持折線圖、柱狀圖、餅圖、散點(diǎn)圖等多種圖表類型 @antv/g2plot 屬于antv庫的一部分 g2plot是在g2基礎(chǔ)上封裝的
npm install @antv/g2plot --save
效果
所有值共享一個(gè)顏色并且每次刷新顏色隨機(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)備,為每個(gè)單詞分配隨機(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ù)項(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>
使用頁面
<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ù)但卻渲染不到頁面上的解決方法
這篇文章主要介紹了vue 獲取到數(shù)據(jù)但卻渲染不到頁面上的解決方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11從0到1構(gòu)建vueSSR項(xiàng)目之路由的構(gòu)建
這篇文章主要介紹了從0到1構(gòu)建vueSSR項(xiàng)目之路由的構(gòu)建,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-03-03深入淺出 Vue 系列 -- 數(shù)據(jù)劫持實(shí)現(xiàn)原理
深入淺出 Vue 系列 -- 數(shù)據(jù)劫持實(shí)現(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,因?yàn)樵诖讼到y(tǒng)上禁止運(yùn)行腳本的相關(guān)資料,這個(gè)報(bào)錯(cuò)是由于在系統(tǒng)上禁止運(yùn)行腳本導(dǎo)致的,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2024-01-01Vue使用自定義指令實(shí)現(xiàn)頁面底部加水印
本文主要實(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ù)用戶權(quán)限動(dòng)態(tài)生成路由配置,實(shí)現(xiàn)此功能可增強(qiáng)應(yīng)用安全性、靈活性,提升用戶體驗(yàn)和開發(fā)效率,本文就來介紹一下前端單獨(dú)實(shí)現(xiàn)vue動(dòng)態(tài)路由的示例代碼,感興趣的可以了解一下2024-09-09