vue中設置echarts寬度自適應的代碼步驟
問題描述
我們使用vue做項目的時候,常常需要做到echarts圖表的自適應,一般是根據(jù)頁面的寬度做對應的適應。本文記錄一下設置echarts圖表的自適應的步驟。我們先看一下沒有做echarts自適應的效果
無自適應效果圖
我們發(fā)現(xiàn)echarts圖的寬度并沒有隨著頁面寬度的變化而變化
有自適應效果圖
很顯然,這個才是我們想要的效果
代碼步驟
echart圖表本身提供了一個resize的函數(shù),我們只需要監(jiān)聽頁面的resize變化以后,去執(zhí)行echarts的resize方法即可重繪canvas,從而實現(xiàn)對應自適應效果。請看代碼中的注釋步驟
<template> <div id="echart"></div> </template> <script> // 第一步,引入echarts插件以供使用 import Echarts from "echarts"; export default { data() { return { myChart: null, // 定義變量用來存放echarts實例 option: { // 配置項寫在data里面方便管理 title: { text: "ECharts 示例", }, tooltip: {}, xAxis: { data: ["襯衫", "羊毛衫", "雪紡衫", "褲子", "高跟鞋", "襪子"], }, yAxis: {}, series: [ { name: "銷量", type: "bar", data: [5, 20, 36, 10, 10, 20], }, ], }, }; }, mounted() { // 第二步,在頁面加載渲染的時候執(zhí)行echarts畫圖方法 this.drawEcharts(); }, methods: { drawEcharts() { // 第三步,通過echarts的init方法實例化一個echarts對象myChart,并,保存在data變量中 this.myChart = Echarts.init(document.getElementById("echart")); // 第四步,執(zhí)行myChart的setOption方法去畫圖,當然至于配置項,我們要提前配置好,這里的配置項 // 寫在data中,方便我們在一些事件中去修改對應配置項,比如點擊按鈕更改配置項數(shù)據(jù) this.myChart.setOption(this.option); // 第五步,在頁面初始化加載的時候綁定頁面resize事件監(jiān)聽。補充resize事件:resize事件是在瀏覽器窗口大小改變時,會觸發(fā)。 // 如當用戶調整窗口大小,或者最大化、最小化、恢復窗口大小顯示時觸發(fā) resize 事件。 // 我們一般使用這個事件去做窗口大小與對應元素的大小適配 window.addEventListener("resize", () => { // 第六步,執(zhí)行echarts自帶的resize方法,即可做到讓echarts圖表自適應 this.myChart.resize(); // 如果有多個echarts,就在這里執(zhí)行多個echarts實例的resize方法,不過一般要做組件化開發(fā),即一個.vue文件只會放置一個echarts實例 /* this.myChart2.resize(); this.myChart3.resize(); ...... */ }); }, beforeDestroy() { /* 頁面組件銷毀的時候,別忘了移除綁定的監(jiān)聽resize事件,否則的話,多渲染幾次 容易導致內存泄漏和額外CPU或GPU占用哦*/ window.removeEventListener("resize", () => { this.myChart.resize(); }); }, }, }; </script> <style lang="less" scoped> #echart { width: 100%; height: 600px; } </style>
到此這篇關于vue中設置echarts寬度自適應的問題及解決方案的文章就介紹到這了,更多相關vue 寬度自適應內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringBoot+Vue項目線上買菜系統(tǒng)源碼展示
本線上買菜系統(tǒng)采用的數(shù)據(jù)庫是Mysql,使用springboot框架開發(fā)。在設計過程中,充分保證了系統(tǒng)代碼的良好可讀性、實用性、易擴展性、通用性、便于后期維護、操作方便以及頁面簡潔等特點,需要的朋友可以參考下2022-08-08vue項目實例中用query傳參如何實現(xiàn)跳轉效果
這篇文章主要介紹了vue項目實例中用query傳參如何實現(xiàn)跳轉效果,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10Vue中使用 setTimeout() setInterval()函數(shù)的問題
這篇文章主要介紹了Vue中使用 setTimeout() setInterval()函數(shù)的問題 ,需要的朋友可以參考下2018-09-09vue2移動端使用vue-qrcode-reader實現(xiàn)掃一掃功能的步驟
最近在使用vue開發(fā)的h5移動端想要實現(xiàn)一個調用攝像頭掃描二維碼的功能,所以下面這篇文章主要給大家介紹了關于vue2移動端使用vue-qrcode-reader實現(xiàn)掃一掃功能的相關資料,需要的朋友可以參考下2023-06-06