vue中設(shè)置echarts寬度自適應(yīng)的代碼步驟
問(wèn)題描述
我們使用vue做項(xiàng)目的時(shí)候,常常需要做到echarts圖表的自適應(yīng),一般是根據(jù)頁(yè)面的寬度做對(duì)應(yīng)的適應(yīng)。本文記錄一下設(shè)置echarts圖表的自適應(yīng)的步驟。我們先看一下沒(méi)有做echarts自適應(yīng)的效果
無(wú)自適應(yīng)效果圖

我們發(fā)現(xiàn)echarts圖的寬度并沒(méi)有隨著頁(yè)面寬度的變化而變化
有自適應(yīng)效果圖

很顯然,這個(gè)才是我們想要的效果
代碼步驟
echart圖表本身提供了一個(gè)resize的函數(shù),我們只需要監(jiān)聽(tīng)頁(yè)面的resize變化以后,去執(zhí)行echarts的resize方法即可重繪canvas,從而實(shí)現(xiàn)對(duì)應(yīng)自適應(yīng)效果。請(qǐng)看代碼中的注釋步驟
<template>
<div id="echart"></div>
</template>
<script>
// 第一步,引入echarts插件以供使用
import Echarts from "echarts";
export default {
data() {
return {
myChart: null, // 定義變量用來(lái)存放echarts實(shí)例
option: { // 配置項(xiàng)寫(xiě)在data里面方便管理
title: {
text: "ECharts 示例",
},
tooltip: {},
xAxis: {
data: ["襯衫", "羊毛衫", "雪紡衫", "褲子", "高跟鞋", "襪子"],
},
yAxis: {},
series: [
{
name: "銷(xiāo)量",
type: "bar",
data: [5, 20, 36, 10, 10, 20],
},
],
},
};
},
mounted() {
// 第二步,在頁(yè)面加載渲染的時(shí)候執(zhí)行echarts畫(huà)圖方法
this.drawEcharts();
},
methods: {
drawEcharts() {
// 第三步,通過(guò)echarts的init方法實(shí)例化一個(gè)echarts對(duì)象myChart,并,保存在data變量中
this.myChart = Echarts.init(document.getElementById("echart"));
// 第四步,執(zhí)行myChart的setOption方法去畫(huà)圖,當(dāng)然至于配置項(xiàng),我們要提前配置好,這里的配置項(xiàng)
// 寫(xiě)在data中,方便我們?cè)谝恍┦录腥バ薷膶?duì)應(yīng)配置項(xiàng),比如點(diǎn)擊按鈕更改配置項(xiàng)數(shù)據(jù)
this.myChart.setOption(this.option);
// 第五步,在頁(yè)面初始化加載的時(shí)候綁定頁(yè)面resize事件監(jiān)聽(tīng)。補(bǔ)充resize事件:resize事件是在瀏覽器窗口大小改變時(shí),會(huì)觸發(fā)。
// 如當(dāng)用戶調(diào)整窗口大小,或者最大化、最小化、恢復(fù)窗口大小顯示時(shí)觸發(fā) resize 事件。
// 我們一般使用這個(gè)事件去做窗口大小與對(duì)應(yīng)元素的大小適配
window.addEventListener("resize", () => {
// 第六步,執(zhí)行echarts自帶的resize方法,即可做到讓echarts圖表自適應(yīng)
this.myChart.resize();
// 如果有多個(gè)echarts,就在這里執(zhí)行多個(gè)echarts實(shí)例的resize方法,不過(guò)一般要做組件化開(kāi)發(fā),即一個(gè).vue文件只會(huì)放置一個(gè)echarts實(shí)例
/*
this.myChart2.resize();
this.myChart3.resize();
......
*/
});
},
beforeDestroy() {
/* 頁(yè)面組件銷(xiāo)毀的時(shí)候,別忘了移除綁定的監(jiān)聽(tīng)resize事件,否則的話,多渲染幾次
容易導(dǎo)致內(nèi)存泄漏和額外CPU或GPU占用哦*/
window.removeEventListener("resize", () => {
this.myChart.resize();
});
},
},
};
</script>
<style lang="less" scoped>
#echart {
width: 100%;
height: 600px;
}
</style>到此這篇關(guān)于vue中設(shè)置echarts寬度自適應(yīng)的問(wèn)題及解決方案的文章就介紹到這了,更多相關(guān)vue 寬度自適應(yīng)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue 集成 PDF.js 實(shí)現(xiàn) PDF 預(yù)覽和添加水印的步驟
這篇文章主要介紹了如何在 Vue 中集成 Mozilla/PDF.js ,實(shí)現(xiàn)自定義的 PDF 預(yù)覽器,以及給被預(yù)覽的 PDF 添加水印2021-01-01
vue使用wavesurfer.js解決音頻可視化播放問(wèn)題
Wavesurfer.js是一款基于HTML5?canvas和Web?Audio的聲紋可視化插件,功能十分強(qiáng)大,在Vue框架中嵌入使用該插件,今天重點(diǎn)給大家介紹下vue使用wavesurfer.js解決音頻可視化播放問(wèn)題,感興趣的朋友一起看看吧2022-04-04
解決Vue 瀏覽器后退無(wú)法觸發(fā)beforeRouteLeave的問(wèn)題
這篇文章主要介紹了解決Vue 瀏覽器后退無(wú)法觸發(fā)beforeRouteLeave的問(wèn)題,需要的朋友可以參考下2017-12-12
vue組件實(shí)現(xiàn)彈出框點(diǎn)擊顯示隱藏效果
這篇文章主要為大家詳細(xì)介紹了vue組件實(shí)現(xiàn)彈出框點(diǎn)擊顯示隱藏,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04
詳解Vue串聯(lián)過(guò)濾器的使用場(chǎng)景
這篇文章主要介紹了詳解Vue串聯(lián)過(guò)濾器的使用場(chǎng)景,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
vue項(xiàng)目中Toast字體過(guò)小,沒(méi)有邊距的解決方案
這篇文章主要介紹了vue項(xiàng)目中Toast字體過(guò)小,沒(méi)有邊距的解決方案。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04

