VUE+elementui组件在table-cell单元格中绘制微型echar
网络编程 2021-07-04 15:02www.168986.cn编程入门
这篇文章主要介绍了VUE+elementui组件在table-cell单元格中绘制微型echarts图,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们狼蚁网站SEO优化随着长沙网络推广来一起学习学习吧
需求效果图示例
实际完成效果图
代码实现
注table表格为二次封装的子组件
-在table表格中 根据 scope.$index动态设置元素的id ,便于指定单元格的echarts初始化;
-在单元格中触发一个方法,传入当前的scope.row数据或者指定其他数据,并且传入 scope.$index 以及一个字符串便于识别当前是哪条数据的charts
-在方法中绘制echarts
<el-table-column align="center"> <template slot="header" slot-scope="scope"> <div v-if="tableTitle == 'sale'"> <p v-if="dateType != '1'"> 近{{ dateType }}天累计 <br /> / 日均销量 </p> <p v-if="dateType == '1'">昨日累计销量</p> </div> <div v-if="tableTitle == 'fav'"> <p v-if="dateType != '1'"> 近{{ dateType }}天累计 <br /> / 日均收藏量 </p> <p v-if="dateType == '1'">昨日累计收藏</p> </div> </template> <div slot-scope="scope" style="white-space:nowrap;"> <span class="xiao-red-color">{{ realRowName(scope.row, '0') || '-' }}</span> <span v-if="dateType != '1'" class="xiao-red-color"> / {{ isNaN(realRowName(scope.row, '0')) ? '-' : (realRowName(scope.row, '0') / (parseInt(dateType) - calcShelfTime(scope.row.real_created_time, '0') < 0 ? parseInt(dateType): calcShelfTime(scope.row.real_created_time, '0'))).toFixed(0)}} </span> </div> </el-table-column> <el-table-column label="每日销量趋势" align="center" v-if="dateType != '1'"> <template slot-scope="scope"> {{ drawEcharts(scope.row, scope.$index, 'sale') }} <div :id="`tiger-sale-trend-index` + scope.$index" class="tiger-trend-charts"></div> </template> </el-table-column>
绘制echarts的方法(数据仅为示例,实际开发根据传进来的scope.row数据)注意此处初始化echarts对象时采用VUE的this.$nextTick方法,以防获取不到未渲染的节点元素。
drawEcharts() { //绘制趋势echarts // console.log(arguments) let option = { tooltip: { trigger: 'axis' }, // legend: { // data: ['每日30天销量分析'] // }, grid: { left: '10px', right: '30px', : '40px', bottom: '10px', containLabel: true }, xAxis: { show: false, type: 'category', boundaryGap: false, data: ['03-21', '03-22', '03-23', '03-24', '03-25', '03-26', '03-27'] }, yAxis: { show: false, type: 'value' }, series: [ { name: '每日30天销量分析', type: 'line', data: [120, 500, 101, 86, 173, 230, 6] } ] }; let chartId = 'tiger-' + arguments[2] + '-trend-index' + arguments[1]; this.$nextTick(() => { let myChart = this.echarts.init(document.getElementById(chartId), 'macarons'); myChart.setOption(option); myChart.resize(); }); },
AND 不要忘记设置echarts的高度,否则一辈子也出不来图形(示例,根据实施开发调整)
&-frame { display: flex; flex-flow: column nowrap; justify-content: space-between; .price-bar { color: red !important; } .tiger-trend-charts { height: 60px; min-width: 100px; } }
到此这篇关于VUE+elementui组件在table-cell单元格中绘制微型echarts图的文章就介绍到这了,更多相关VUE elementui 单元格echarts图内容请搜索狼蚁SEO以前的文章或继续浏览狼蚁网站SEO优化的相关文章希望大家以后多多支持狼蚁SEO!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程