echarts+vue_vue安装echarts

echarts+vue_vue安装echarts1.安装cnpminstallecharts-wordcloud2.创建模板组件WordCloudChart<template><div:id=”id”:style=”{height:height,width:width}”/></template><script>importechartsfrom”echarts/lib/echarts”;importresizefrom”@/m

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

1. 安装

cnpm install echarts-wordcloud

2. 创建模板组件

  • WordCloudChart
<template>
<div :id="id" :style="{ 
 height:height,width:width }" />
</template>
<script> import echarts from "echarts/lib/echarts"; import resize from "@/mixins/resize"; import "echarts-wordcloud/dist/echarts-wordcloud"; import "echarts-wordcloud/dist/echarts-wordcloud.min"; export default { 
 mixins: [resize], props: { 
 className: { 
 type: String, default: "chart" }, id: { 
 type: String, default: "chart" }, width: { 
 type: String, default: "100%" }, height: { 
 type: String, default: "400px" }, data: { 
 type: Array, default: [] }, title: { 
 type: String, default: "" } }, data() { 
 return { 
 chart: null }; }, watch: { 
 data(data) { 
 this.initChart(); }, }, mounted() { 
 this.initChart(); }, beforeDestroy() { 
 if (!this.chart) { 
 return; } this.chart.dispose(); this.chart = null; }, methods: { 
 initChart() { 
 this.chart = echarts.init(document.getElementById(this.id)); //let maskImage = new Image(); /*自定义形状关键点1*/ //maskImage.src = ""; //maskImage.src = require('@/assets/c.png') let option = { 
 title: { 
 text: this.title, x: "center" }, backgroundColor: "#fff", tooltip: { 
 show: true, formatter: function (data) { 
 let result = "<span>词条名称:</span><span>"+data.data.name+"</span><br/>"; result += "<span>词条数量:</span><span>"+data.data.value+"</span><br/>"; result += "<span>词条覆盖率:</span><span>"+data.data.rate+"%</span><br/>"; return result; } }, // tooltip: { 
 // pointFormat: "{series.name}: <b>{point.percentage:.1f}%</b>" // }, series: [ { 
 type: "wordCloud", //用来调整词之间的距离 gridSize: 15, //用来调整字的大小范围 // Text size range which the value in data will be mapped to. // Default to have minimum 12px and maximum 60px size. sizeRange: [15, 80], // Text rotation range and step in degree. Text will be rotated randomly in range [-90, 90] by rotationStep 45 //用来调整词的旋转方向,,[0,0]--代表着没有角度,也就是词为水平方向,需要设置角度参考注释内容 // rotationRange: [-45, 0, 45, 90], // rotationRange: [ 0,90], rotationRange: [0, 0], //随机生成字体颜色 //shape:'circle', //maskImage: maskImage, textStyle: { 
 normal: { 
 color: function(data) { 
 console.log("color-data") console.log(data) let colors = [ '#092d52', '#2b4968', '#0f387a', '#336190', '#3d87d2', '#5690cc', '#68a3f5', '#7e9fc2', '#a7bdd4' ] /*return ( "rgb(" + Math.round(Math.random() * 255) + ", " + Math.round(Math.random() * 255) + ", " + Math.round(Math.random() * 255) + ")" );*/ return colors[parseInt(data.dataIndex / 4)]; } /*color: [ '#092d52', '#2b4968', '#0f387a', '#336190', '#3d87d2', '#5690cc', '#68a3f5', '#7e9fc2', '#a7bdd4' ]*/ } }, //位置相关设置 // Folllowing left/top/width/height/right/bottom are used for positioning the word cloud // Default to be put in the center and has 75% x 80% size. left: "center", top: "center", right: null, bottom: null, width: "100%", height: "100%", //数据 data: this.data } ] }; /*let _self = this; maskImage.onload = function(){ /!* 自定义形状,关键点4*!/ _self.chart.setOption(option); };*/ this.chart.setOption(option); } } }; </script>
<style lang='scss' scoped> .chartsClass { 
 padding-left: 1.2rem; } </style>
  • resize.js
export default { 

data() { 

return { 

$_sidebarElm: null
}
},
mounted() { 

this.__resizeHandler = this.debounce(() => { 

if (this.chart) { 

this.chart.resize()
}
}, 100)
window.addEventListener('resize', this.__resizeHandler)
this.$_sidebarElm = document.getElementsByClassName('sidebar-container')[0]
this.$_sidebarElm && this.$_sidebarElm.addEventListener('transitionend', this.$_sidebarResizeHandler)
},
beforeDestroy() { 

window.removeEventListener('resize', this.__resizeHandler)
this.$_sidebarElm && this.$_sidebarElm.removeEventListener('transitionend', this.$_sidebarResizeHandler)
},
methods: { 

// use $_ for mixins properties
// https://vuejs.org/v2/style-guide/index.html#Private-property-names-essential
$_sidebarResizeHandler(e) { 

if (e.propertyName === 'width') { 

this.__resizeHandler()
}
},
debounce(func, wait, immediate) { 

let timeout, args, context, timestamp, result
const later = function () { 

// 据上一次触发时间间隔
const last = +new Date() - timestamp
// 上次被包装函数被调用时间间隔 last 小于设定时间间隔 wait
if (last < wait && last > 0) { 

timeout = setTimeout(later, wait - last)
} else { 

timeout = null
// 如果设定为immediate===true,因为开始边界已经调用过了此处无需调用
if (!immediate) { 

result = func.apply(context, args)
if (!timeout) context = args = null
}
}
}
}
}
}

3. 使用时引用

<!-- 图表案例 -->
<template>
<div>
<el-row>
<!--<el-radio-group size="mini" v-model="pType" style="margin-bottom: 30px;" @change="typeChange"> <el-radio-button label="left">全部</el-radio-button> <el-radio-button label="center">坐席</el-radio-button> <el-radio-button label="right">客户</el-radio-button> </el-radio-group>-->
</el-row>
<el-row>
<el-col :span="12">
<div class="nodata" v-if="words.length == 0"></div>
<!--<vue-word-cloud v-else="words.length == 0" style="width:500px;height:500px;" :words="words" :color="([, weight]) => weight % 9 == 0 ? colors[0] : weight % 8 == 0 ? colors[1] : weight % 7 == 0 ? colors[2] : weight % 6 == 0 ? colors[3] : weight % 5 == 0 ? colors[4] : weight % 4 == 0 ? colors[5] : weight % 3 == 0 ? colors[6] : weight % 2 == 0 ? colors[7] : colors[8]" font-family="Roboto" :font-size-ratio="fontSizeRatio" :spacing="spacing" :spiral="'rectangular'" > <template slot-scope="{text, weight, word}"> <div :title="txtMove(word)" style="cursor: pointer;">{ 
{ text }}</div> </template> </vue-word-cloud>-->
<word-cloud-chart id="chartId" :title="''" :data="echarts05Data" :width="'500px'" :height="'500px'" >
</word-cloud-chart>
</el-col>
<el-col :span="12">
<el-table :data="tableData" height="500" border style="width: 100%">
<!--<el-table-column type="expand"> <template slot-scope="props"> { 
{props.row.topicName}} </template> </el-table-column>-->
<el-table-column type="index" label="序号" min-width="9%" align="center"></el-table-column>
<!--:sort-method="sortDevName"-->
<el-table-column prop="topicName" label="词条名称" sortable min-width="27%"></el-table-column>
<el-table-column prop="topicNum" sortable label="词条数量" min-width="18%"></el-table-column>
<el-table-column prop="topicCoverRate" sortable label="词条覆盖率" min-width="19%">
<template slot-scope="scope">
<span>{
{scope.row.topicCoverRate}}%</span>
</template>
</el-table-column>
<el-table-column v-if="!isShowOperation" min-width="14%" align="center" prop="address" label="操作" >
<template slot-scope="scope">
<el-button @click="handle(scope.row)" type="text" size="small">查看明细</el-button>
</template>
</el-table-column>
</el-table>
</el-col>
</el-row>
</div>
</template>
<style> #chart { 
 display: inline-block; width: 100%; height: 300px; /*pointer-events : none;*/ } </style>
<script> import VueWordCloud from "vuewordcloud"; import { 
 getFaq } from "@/api/enterprise/phoneBusinessTheme/complainCause" import qs from "qs"; import { 
 detailedRouter } from "@/utils/detailedRouter"; import WordCloudChart from "@/components/WordCloudChart" export default { 
 components: { 
 VueWordCloud, WordCloudChart }, props: { 
 repeatComplain: { 
 type: Number }, types: { 
 type: Object }, tabIndex: { 
 type: Number }, type: { 
 type: String }, formInline: { 
 type: Object }, levelName: { 
 type: String }, clientIssue: { 
 type: String }, isShowOperation: { 
 type: Boolean, defalult: false }, firstGradeHotWords: { 
 type: String } }, mounted() { 
}, watch: { 
 firstGradeHotWords: "changeFirstGradeHotWords" }, data() { 
 let options = qs.parse(location.search, { 
 ignoreQueryPrefix: true }); return { 
 options, //面板 pType: "left", spacing: 0.3, fontSizeRatio: 5, colors: [ '#092d52', '#2b4968', '#0f387a', '#336190', '#3d87d2', '#5690cc', '#68a3f5', '#7e9fc2', '#a7bdd4' ], words: [ //['暂无数据', 1499] ], tableData: [], firstGradeWordsCompare: "", // 对比时用的一级 clientIssueCompare: "", // 对比时用的文本检索 echarts05Data: [ ] }; }, created() { 
 let params = { 
}; this.initParams(params); this.initData(params); }, methods: { 
 sortDevName(str1, str2) { 
 let res = 0; for (let i = 0; ; i++) { 
 if (!str1[i] || !str2[i]) { 
 res = str1.length - str2.length; break; } const char1 = str1[i]; const char1Type = this.getChartType(char1); const char2 = str2[i]; const char2Type = this.getChartType(char2); // 类型相同的逐个比较字符 if (char1Type[0] === char2Type[0]) { 
 if (char1 === char2) { 
 continue; } else { 
 if (char1Type[0] === "zh") { 
 res = char1.localeCompare(char2); } else if (char1Type[0] === "en") { 
 res = char1.charCodeAt(0) - char2.charCodeAt(0); } else { 
 res = char1 - char2; } break; } } else { 
 // 类型不同的,直接用返回的数字相减 res = char1Type[1] - char2Type[1]; break; } } return res; }, getChartType(char) { 
 // 数字可按照排序的要求进行自定义,我这边产品的要求是 // 数字(0->9)->大写字母(A->Z)->小写字母(a->z)->中文拼音(a->z) if (/^[\u4e00-\u9fa5]$/.test(char)) { 
 return ["zh", 300]; } if (/^[a-zA-Z]$/.test(char)) { 
 return ["en", 200]; } if (/^[0-9]$/.test(char)) { 
 return ["number", 100]; } return ["others", 999]; }, changeFirstGradeHotWords() { 
 console.log(this.firstGradeHotWords); let params = { 
}; this.initParams(params); //筛选条件如果是全部,传过来" ",不用处理,还是取formInline里的值 if (this.firstGradeHotWords !== "") { 
 params.firstGradeComplain = this.firstGradeHotWords; } this.initData(params); }, txtMove(_item) { 
 let result = /*"词条名称:" + _item[0] + "\n词条数量:" + _item[1] + "\n词条覆盖率:" + _item[2] + "%\n";*/ "aaa"; return result; }, handle(row) { 
 /*row.jumpFrom = "howWords"; row.firstGrade = this.firstGradeHotWords; this.formInlineCopy = this.formInline; let json = { formInlineCopy: this.formInlineCopy, data: row }; this.$router.push({ path: "/npsTheme/npsDataDetail", query: { json: json } });*/ this.formInlineCopy = this.formInline; if (this.repeatComplain && this.repeatComplain === 1) { 
 this.formInlineCopy.isComplain = "是" this.formInlineCopy.numOfComplain = 2; //后台处理大于等于 } this.formInlineCopy.topicName = row.topicName; //一级类别 if (this.firstGradeHotWords !== "") { 
 this.formInlineCopy.classifyA = this.firstGradeHotWords; } let json = { 
 "formInlineCopy": this.formInlineCopy, }; let themeName = "complainCause" detailedRouter(this, json, themeName); }, typeChange(value) { 
 console.log(value); this.initData(); }, initParams(params1) { 
 if (this.firstGradeHotWords !== "") { 
 params1.firstGradeComplain = this.firstGradeHotWords; } else { 
 params1.firstGradeComplain = ""; } params1.startTime = this.formInline.time[0]; params1.endTime = this.formInline.time[1]; /*let a1 = new Array(); a1.push(this.formInline.business); params1.typeOfJob = this.formInline.business == '' ? '' : a1; let a2 = new Array(); a2.push(this.formInline.institution); params1.areaOfJob = this.formInline.institution == '' ? '' : a2;*/ params1.typeOfJob = this.formInline.business; params1.areaOfJob = this.formInline.institution; params1.product = this.formInline.product; params1.repGroup = this.formInline.repGroup; params1.repNo = this.formInline.repNo; params1.custName = this.formInline.custName; params1.callNumber = this.formInline.callNumber; params1.numOfComplain = this.formInline.numOfComplain; params1.isComplain = "是" if (this.repeatComplain && this.repeatComplain === 1) { 
 params1.isComplain = "是" params1.numOfComplain = 2; //后台处理大于等于 } if (this.clientIssue) { 
 params1.matchEvalWordTriplet = this.clientIssue; } //发请求时把一级存住,对比中使用 if (this.firstGradeHotWords !== undefined ) { 
 this.formInline.firstGradeWordsCompare = JSON.parse(JSON.stringify(this.firstGradeHotWords)); } if (this.formInline.firstGradeWordsCompare!== undefined) { 
 params1.firstGradeComplain = this.formInline.firstGradeWordsCompare } //发请求时把文本框存住,对比中使用 if (this.clientIssue !== undefined ) { 
 this.formInline.clientIssueCompare = JSON.parse(JSON.stringify(this.clientIssue)); } if (this.formInline.clientIssueCompare!== undefined) { 
 params1.matchEvalWordTriplet = this.formInline.clientIssueCompare } /*if(this.levelName){ if(this.levelName.indexOf(",") != -1){ let _callResult = this.levelName.split(",")[0]; let _firstLevel = this.levelName.split(",")[1]; params1.callResult = _callResult; params1.firstLevel = [_firstLevel]; }else{ params1.firstLevel = [this.levelName]; } }*/ }, initData(params) { 
 getFaq(params).then(res => { 
 if (!res.words || res.words.length == 0) { 
 this.tableData = []; this.words = [ //['暂无数据', 1499] ]; this.echarts05Data = []; } let tables = res.list; //if(tables.length > 20)tables.length = 20; let wordsData = res.words; if (wordsData.length > 30) wordsData.length = 30; let echarts05Data = [] for (let i = 0; i < wordsData.length; i++) { 
 let json = { 
 name: wordsData[i][0], value: wordsData[i][1], rate: wordsData[i][2] } echarts05Data.push(json); } this.echarts05Data = echarts05Data; this.tableData = tables; this.words = wordsData; }) .catch(err => { 
 console.log(err); }); }, // 数据转换 formatJson(filterVal, jsonData) { 
 return jsonData.map(v => filterVal.map(j => { 
 if (j == "topicCoverRate") { 
 return v[j] + "%"; } return v[j]; }) ); }, downloadFAQ() { 
 for (let i = 0; i < this.tableData.length; i++) { 
 this.tableData[i].index = i + 1; } if (!this.tableData || this.tableData.length === 0) { 
 this.$message({ 
 message: "暂无数据", type: "warning", duration: 2500 }); } else if (this.tableData.length > 0) { 
 let _self = this; //用来刷新按钮小图标的 import("@/vendor/Export2Excel").then(excel => { 
 const tHeader = ["序号", "词条名称", "词条数量", "词条覆盖率"]; const filterVal = ["index", "topicName", "topicNum", "topicCoverRate"]; const data = this.formatJson(filterVal, _self.tableData); excel.export_json_to_excel({ 
 header: tHeader, data, filename: "热词分析" }); }); } } } }; </script>

4.echartswordcloud和vuewordcloud对比

  1. echarts有自带的提示框,可自定义;vuewordcloud需要手写一个
  2. echarts初始化是一个一个词出,不会感觉特别慢;vuewordcloud是等所有词一起出现
  3. echarts中数量和颜色的关系需要自己定义;vuewordcloud直接传color就好
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/184170.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • pki密码技术_密码学入门

    pki密码技术_密码学入门CA中心——CA系统——数字证书CA中心管理并运营CA系统,CA系统负责颁发数字证书。专门负责颁发数字证书的系统称为CA系统,负责管理并运营CA系统的机构称为CA中心。所有与数字证书相关的各种概念和技术,统称为PKI(PublicKeyInfrastructure)。传统密码学换位加密法; 替换加密法;现代密码学加密基元加密基元就是一些基础的密码学算法,通过它们才能够构建更多的密码学算法、协议、应用程序。说明:散列函数(散列(hash)、.

  • 古今计算机发展简史思维导图_计算机功能演变史

    古今计算机发展简史思维导图_计算机功能演变史小时候,见过电子计算器,能很快完成计算,当时心想,计算器真是厉害,能提前存下所有数字的加减乘除结果。现在想来,很傻很天真。后来,吵着闹着要买小霸王学习机,最后如愿变成游戏机,经典游戏“超级玛丽”和“坦克大战”至今历历在目。

    2022年10月18日
  • cacls批量权限控制

    cacls批量权限控制

  • 光猫不改桥接外网能访问吗_光猫桥接的利弊

    光猫不改桥接外网能访问吗_光猫桥接的利弊因为群晖需要外网访问,将自购的路由器改为拨号上网,光猫设置为桥接模式。但这种情况下,因为路由的网段(我的是192.168.3.x)和光猫的网段(电信,默认192.168.1.x)不同,此时不能通过192.168.1.1网址来连接光猫,网上也有将光猫称作副路由。解决方法:1、在光猫中插入一根网线,通过有线的方式连接到电脑。现在的笔记本很多都不带RJ45网口,还需要另外准备转接头和网线。2、临时将路由的上网方式变更为自动获取,然后就可以连接192.168.1.1。这种方法的缺点是

  • Django(23)Django限制请求装饰器

    Django(23)Django限制请求装饰器前言有时候,我们想要限制访问的请求方法,比如我们希望用户只能通过get方式请求,post不允许,那么我们可以采用装饰器的方式,django已经为我们提供了内置的装饰器限制请求装饰器Django内

  • XXE实体注入(超详细!)

    XXE实体注入(超详细!)可以把它理解为txt,就是存储文件的,读取并调用出来,这是最核心的将你的代码当成XXE代码,然后XXE再交给PHP去执行将1.txt的东西,放入test这个变量实体就是变量&test就是输出这个变量<scan></scan>只是一个声明格式,随便写什么,就算写成<abc></abc>都可以,只要满足<x></x>格式就行最主要的是访问的地址,file,http等协议都可以。XXE:XML外部实体注入,原理:.

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号