VueWordCloud标签云初实现

文章目录

VueWordCloud学习总结

本次小组官网的项目中自己要负责标签模块,想要实现一个标签云的效果,搜索了很多,发现vue有一个VueWordCloud库,之前看的github仓库一直是老版本的不支持Vue3,今天搜到了新版本更新至支持Vue3的版本,仓库链接附上:VueWordCloud

安装

bash 复制代码
npm i vuewordcloud

初使用

在组件中注册该组件

typescript 复制代码
import VueWordCloud from 'vuewordcloud';

简单使用

words:标签云展示的标签

color:不同的weight对应不同的颜色,根据weight来决定颜色

font-family:字体(官方文档中给了很多字体,详情可参考上方仓库链接)

html 复制代码
<vue-word-cloud
  style="height: 480px;width: 640px;"
  :words="[['romance', 19], ['horror', 3], ['fantasy', 7], ['adventure', 3]]"
  :color="([, weight]) => weight > 10 ? 'DeepPink' : weight > 5 ? 'RoyalBlue' : 'Indigo'"
  font-family="Roboto"
/>

项目中实现

由于每个标签对应的都有一个详情页,所以标签云不仅要展示标签,还需要进行路由跳转,用到了另一个渲染方式(单词传递自定义渲染)

为了展示时颜色更加好看,weight范围可以取小一点,多种颜色

html 复制代码
<vue-word-cloud :words="words"
   :color="([, weight]) => weight > 50 ? '#552af4' : weight > 47 ? '#412045' : weight > 45 ? '#5bc496' : weight > 42 ? '#f3cf77' : weight > 40 ? '#416af6' : weight > 38 ? '#eb7eb1' : weight > 35 ? '#ee8231' : weight > 32 ? '#552af4' : weight > 30 ? '#ae8af0' : weight > 25 ? '#579ce4' : '#ec5c6c'"
   font-family="微软雅黑,Microsoft YaHei" spacing="0.2">
   <template v-slot="{ text }">
       <div style="cursor: pointer;">
           <router-link active-class="active" :to="`/community/discussion/label/${text}`">
             {{ text }}</router-link>
       </div>
   </template>
</vue-word-cloud>

由于后端传来的words数组只有标签名,所以写了一个方法使每个标签都随机生成一个对应的数值,因为数值越小标签展示到页面上也就越小,为了防止标签过于小用户视觉体验不好,所以设置数值不会取太小的值

typescript 复制代码
function assignRandomNumbers(strArray: string[]): [string, number][] {
    return strArray.map(str => [str, Math.floor(Math.random() * (30 + 1)) + 20]); 
}

最终实现效果

官方仓库中还有很多的属性,可以设置更好看更高级的标签云,详情可看官方仓库

相关推荐
像我这样帅的人丶你还15 小时前
别再让JS耽误你进步了。
css·vue.js
@yanyu66615 小时前
07-引入element布局及spring boot完善后端
javascript·vue.js·spring boot
王霸天15 小时前
💥别再抄网上的Scale缩放代码了!50行源码教你写一个永不翻车的大屏适配
前端·vue.js·数据可视化
悟空瞎说16 小时前
深入 Vue3 响应式:为什么有的要加.value,有的不用?从设计到源码彻底讲透
前端·vue.js
SuperEugene18 小时前
前端通用基础组件设计:按钮/输入框/弹窗,统一设计标准|组件化设计基础篇
前端·javascript·vue.js·架构
我命由我1234518 小时前
在 React 项目中,可以执行 npm start 命令,但是,无法执行 npm build 命令
前端·javascript·vue.js·react.js·前端框架·json·ecmascript
aidou131418 小时前
Vue3自定义实现日期选择器(可单选或多选)
前端·javascript·vue.js·日期选择器·transition
忆琳19 小时前
Vue3 优雅解决单引号注入问题:自定义指令 + 全局插件双方案
vue.js·element
落魄江湖行20 小时前
入门篇八 Nuxt4页面元信息与 SEO:让搜索引擎爱上你的网站
前端·typescript·seo·nuxt4
LcGero20 小时前
TypeScript 快速上手:前言
typescript·cocos creator·游戏开发