您好,登錄后才能下訂單哦!
這篇文章主要講解了“Vue怎么封裝Echarts圖表”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“Vue怎么封裝Echarts圖表”吧!
在開始之前,我們先按照正常的組件注冊流程,在項目components目錄中新建一個名為radar-chart的組件,然后在一個Demo頁面引入該組件使用。
新建的 radar-chart 組件內容:
// radar-chart.vue (子組件) <template> <p style="width: 100%; height: 100%;"></p> </template> <script> export default { name: 'radar-chart' }; </script> <style scoped> </style>
Demo 頁面代碼:
// demo.vue (父組件) <template> <p style="border: 1px solid black; width: 400px; height: 300px; margin: 5px;"> <radar-chart></radar-chart> </p> </template> <script> import radarChart from '@/components/proj-components/echarts/radar-chart'; export default { name: 'radar-chart-demo', components: { radarChart, }, }; </script> <style scoped> </style>
Demo 頁面效果圖一:
初始化圖表
準備工作完成之后,我們要做的是引入 ECharts,并在組件中初始化一個 ECharts 的實例,這里可以先照搬官網的實例和數據。
(1)在 radar-chart.vue 引入 ECharts :
// radar-chart.vue (子組件) import echarts from 'echarts';
(2)在 methods 中創建圖表配置數據的方法,數據格式參考 Echarts 官網:
// radar-chart.vue (子組件) methods: { // 初始化圖表配置 initOption() { let vm = this; vm.option = { title: { text: '基礎雷達圖' }, tooltip: {}, legend: { data: ['預算分配(Allocated Budget)', '實際開銷(Actual Spending)'] }, radar: { // shape: 'circle', name: { textStyle: { color: '#fff', backgroundColor: '#999', borderRadius: 3, padding: [3, 5] } }, indicator: [{ name: '銷售(sales)', max: 6500}, { name: '管理(Administration)', max: 16000}, { name: '信息技術(Information Techology)', max: 30000}, { name: '客服(Customer Support)', max: 38000}, { name: '研發(Development)', max: 52000}, { name: '市場(Marketing)', max: 25000}] }, series: [{ name: '預算 vs 開銷(Budget vs spending)', type: 'radar', // areaStyle: {normal: {}}, data: [{value: [4300, 10000, 28000, 35000, 50000, 19000], name: '預算分配(Allocated Budget)'}, {value: [5000, 14000, 28000, 31000, 42000, 21000], name: '實際開銷(Actual Spending)'}] }] }; }, },
(3)初始化圖表: 在組件鉤子 mounted 方法中:
// radar-chart.vue (子組件) mounted() { this.initOption(); this.$nextTick(() => { // 這里的 $nextTick() 方法是為了在下次 DOM 更新循環結束之后執行延遲回調。也就是延遲渲染圖表避免一些渲染問題 this.ready(); }); },
在 methods 中:
// radar-chart.vue (子組件) ready() { let vm = this; let dom = document.getElementById('radar-chart'); vm.myChart = echarts.init(dom); vm.myChart && vm.myChart.setOption(vm.option); },
Demo 頁面效果圖二:
這里一共分了三步,引入 ECharts、初始化圖表配置、初始化圖表,最后可以在 Demo 頁面中看到,已經初步地把 ECharts 的雷達圖顯示到項目中來了。
提取圖表配置屬性(重點)
上面我們已經成功創建一個雷達圖了,但是很明顯的是,radar-chart.vue 里的數據寫死的,無法重復調用。接下來著手封裝的事情了。
封裝的思路是這樣的:
1、demo.vue 向 radar-chart.vue 傳遞一組個性化數據
2、radar-chart.vue 通過 props 選項接收數據
3、提煉接收到的數據,覆蓋配置數據 option
4、初始化圖表
具體實現: 向子組件傳遞數據,在 data 中定義變量,在 mounted 中賦值
// demo.vue (父組件) <template> <p style="border: 1px solid black; width: 900px; height: 600px; margin: 5px;"> <radar-chart :indicator="indicator" :legendData="radarData"></radar-chart> </p> </template> <script> import radarChart from '@/components/proj-components/echarts/radar-chart'; export default { name: 'radar-chart-demo', components: { radarChart, }, mounted() { this.indicator = [ { name: '銷售', max: 6500 }, { name: '管理', max: 16000 }, { name: '信息技術', max: 30000 }, { name: '客服', max: 38000 }, ]; this.radarData = [ { value: [4000, 15000, 26000, 21000], name: '實際開銷(Actual Spending)', } ]; }, data() { return { indicator: [], // 雷達指示器數據 legendData: [], // 雷達圖例數據 }; }, }; </script> <style scoped> </style>
在 props 中接收來自父組件的數據
// radar-chart.vue (子組件) props: { // 指示器數據,必傳項 // 格式舉例 [{ name: 'a', max: 1},{ name: 'a', max: 1},{ name: 'a', max: 1}] indicator: { type: Array, default: () => [] }, // 圖例數據,必填項。 // 格式舉例 [{ value: [5000, 14000, 28000], name: 'name' },{ value: [5000, 14000, 28000], name: 'name' }] legendData: { type: Array, default: () => [] }, },
在 ready() 中更新圖表數據 option 如果在這里更新 indicator、data 這兩個屬性值,initOption() 中就不需要初始化這兩個值了
// radar-chart.vue (子組件) ready() { let vm = this; let dom = document.getElementById('radar-chart'); vm.myChart = echarts.init(dom); // 得到指示器數據 vm.option.radar.indicator = vm.indicator; // 得到圖例數據 vm.option.series[0].data = vm.legendData; vm.myChart && vm.myChart.setOption(vm.option); },
Demo 頁面效果圖三:
細節優化與其他注意事項:
1.一個頁面有多個圖表的情況下,自動生成圖表 ID。
// radar-chart.vue (子組件) <template> <p :id="chartId" style="height: 100%; width: 100%;"></p> </template> <script> let chartIdSeed = 1; export default { data() { return { chartId: 1, }; }, mounted() { let vm = this; vm.chartId = 'radar-chart_' + chartIdSeed++; }, methods: { let vm = this; let dom = document.getElementById(vm.chartId); } }; </script>
2.圖表數據屬性用 props 接收,圖表默認配置屬性用 defaultConfig 保存,父組件傳入的配置屬性 chartConfig 通過 $attrs 直接取得,最終合并為 finallyConfig 使用,利于擴展與維護。
// radar-chart.vue (子組件) <script> export default { data() { return { // 默認配置項。以下配置項可以在父組件 :chartConfig 進行配置,會覆蓋這里的默認配置 defaultConfig: { tooltipShow: true }, finallyConfig: {}, // 最后配置項 }; }, mounted() { // 在這里合并默認配置與父組件傳進來的配置 vm.finallyConfig = Object.assign({}, vm.defaultConfig, vm.$attrs.chartConfig); }, methods: { initOption() { vm.option = { tooltip: { show: vm.finallyConfig.tooltipShow, // 在這里使用最終配置 }, } }, } }; </script>
3.使用 watch 監聽圖表數據更新
// radar-chart.vue (子組件) watch: { legendData() { this.$nextTick(() => { this.ready(); }); } },
4.添加窗口 resize 事件和圖表 click 事件
// radar-chart.vue (子組件) export default { data() { return { chartResizeTimer: null, // 定時器,用于resize事件函數節流 }; }, methods: { ready() { // 添加窗口resize事件 window.addEventListener('resize', vm.handleChartResize); // 觸發父組件的 @chartClick 事件 vm.myChart.on('click', function(param) { vm.$emit('chartClick', param); }); }, // 處理窗口resize事件 handleChartResize() { let vm = this; clearTimeout(vm.chartResizeTimer); vm.chartResizeTimer = setTimeout(function() { vm.myChart && vm.myChart.resize(); }, 200); }, }, beforeDestroy() { // 釋放該圖例資源,較少頁面卡頓情況 if (this.myChart) this.myChart.clear(); // 移除窗口resize事件 window.removeEventListener('resize', this.handleChartResize); } };
感謝各位的閱讀,以上就是“Vue怎么封裝Echarts圖表”的內容了,經過本文的學習后,相信大家對Vue怎么封裝Echarts圖表這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。