<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
需要大量使用圖表的專案,為了提升開發效率,可以對圖表類進行封裝成元件,方便頁面的搭建,也能進行統一管理維護,即使後面系統風格需要調整,調整起來也比較方便、快速。
常用的有Echarts、AntV,使用起來都大同小異,具體圖表如何實現,看官網引數進行設定調整即可。
以Echarts為例,效果截圖
npm install echarts --save npm install vue-echarts --save npm install --save @vue/composition-api // 最終安裝版本 // "echarts": "^5.3.2", // "vue-echarts": "^6.0.3", // "@vue/composition-api": "^1.6.1",
<template> <v-chart ref="myChart" class="echarts" :style="{height: height}" :option="option" autoresize @click="click" /> </template> <script> // eslint-disable-next-line no-unused-vars import echarts from 'echarts' import VChart from 'vue-echarts' export default { name: 'EchartLine', components: { VChart }, props: { dataSource: { type: Object, default: () => { return {} } }, chartOption: { type: Object, default: () => { return {} } }, height: { type: String, default: '340px' }, unit: { type: String, default: '' } }, computed: { option () { const option = { title: _.assign({}, this.defaultOption.title, this.chartOption.title || {}), tooltip: _.assign({}, this.defaultOption.tooltip, this.chartOption.tooltip || {}), grid: _.assign({}, this.defaultOption.grid, this.chartOption.grid || {}), legend: _.assign({}, this.defaultOption.legend, this.chartOption.legend || {}), xAxis: _.assign({}, this.defaultOption.xAxis, this.chartOption.xAxis, {data: this.dataSource.xAxis}), yAxis: _.assign({}, this.defaultOption.yAxis, this.chartOption.yAxis || {}), series: _.map(this.dataSource.yAxis, dataItem => { return { type: 'line', symbol: dataItem.symbol || 'circle', smooth: dataItem.smooth !== false, symbolSize: dataItem.symbolSize || 8, showSymbol: dataItem.showSymbol || (dataItem.data.length === 1), name: dataItem.name, data: dataItem.data, itemStyle: { color: dataItem.color, borderColor: 'rgba(255,255,255,0.8)', borderWidth: 2 } } }) } return option } }, data () { return { defaultOption: { title: { x: '5%' }, tooltip: { trigger: 'axis', textStyle: { color: '#fff' }, backgroundColor: 'rgba(51,51,51,0.80)', padding: [14, 20] }, grid: { top: '15%', left: '24', right: '24', bottom: '60', containLabel: true }, legend: { left: 'center', bottom: '26', itemGap: 25, itemWidth: 8, itemHeight: 8, show: true, icon: 'circle', textStyle: { color: () => { return _.map(this.dataSource.yAxis, item => { return item.color }) } } }, xAxis: { axisLabel: { margin: 12, textStyle: { color: '#666' } }, axisTick: { show: false }, axisLine: { lineStyle: { color: '#E8E8E8' } }, splitLine: { show: false } }, yAxis: { minInterval: 1, splitNumber: 5, axisLine: { show: true, lineStyle: { color: '#E8E8E8' } }, splitLine: { show: true, lineStyle: { color: '#E8E8E8', opacity: 0.5, type: 'dotted' } }, axisTick: { show: false }, axisLabel: { textStyle: { color: '#666' } } } } } }, methods: { click (e) { this.$emit('click', e) } } } </script> <style lang="scss" scoped> .echarts{ width: 100%; height: 100%; } </style>
<template> <EchartLine :dataSource="dataSource"></EchartLine> </template> <script> import EchartLine from '@/components/EchartLine' export default { name: 'EchartsDemo', components: { EchartLine }, data () { return { dataSource: { xAxis: ['星期一', '星期二', '星期三', '星期四', '星期五'], yAxis: [ { name: '語文', color: '#FF6F00', data: [45, 56, 24, 87, 45] }, { name: '數學', color: '#FFB903', data: [34, 86, 67, 34, 89] }, { name: '英語', color: '#3D8BFF', data: [66, 83, 45, 77, 73] } ] } } }, methods: { } } </script>
Tips:
vue-echarts資料:github.com/ecomfe/vue-…
echarts v5各引數設定:echarts.apache.org/zh/option.h…
到此這篇關於vue-echarts如何實現圖表元件封裝的文章就介紹到這了,更多相關vue-echarts圖表元件封裝內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45