vue?echarts實現(xiàn)改變canvas長和寬自適應(yīng)
echarts改變canvas長寬自適應(yīng)
存放Echarts的DOM容器,如果給的高和寬是百分比,渲染的時候DOM容器的高和寬是按百分比給的,但是DOM容器下的子元素div和canvas高和寬是根據(jù)圖標(biāo)內(nèi)容渲染。項目應(yīng)用的時候,底部會有一部分DOM容器和div的高度差,不美觀。
希望Echarts的canvas和DOM容器的高寬一致。
下面給出代碼
方法一:根據(jù)瀏覽器寬高為echarts容器賦寬高
<template>
<div id="main"></div>
</template>
<script>
import echarts from 'echarts'
export default {
name: "Chart",
mounted() {
var myChartContainer = document.getElementById('main')
// 獲取自適應(yīng)的高度和寬度
var resizeMyChartContainer = function() {
myChartContainer.style.height = window.innerHeight * 0.65 + 'px';
myChartContainer.style.width = window.innerWidth * 0.75 + 'px';
};
// 設(shè)置容器高和寬
resizeMyChartContainer();
var myChart = echarts.init(myChartContainer);
let option = {};
myChart.setOption(option);
// 自適應(yīng)高和寬
window.onresize = function () {
resizeMyChartContainer();
myChart.resize();
}
}
}
</script>
這里的DOM容器下的div和canvas高和寬和DOM容器一樣了

錯誤1
document.getElementById('main').firstChild.firstChild.style.height = window.innerHeight * 0.55 + 'px'如果強(qiáng)行獲取canvas元素,改變它的高度(上面的div和DOM高度都不變),會把echarts拉高,圖像也拉高了,比例不對。
錯誤2
var myChart = echarts.init(myChartContainer, {width:'800px',height:'400px'});
在初始化的時候傳入高和寬,此時DOM元素下的div和canvas的高和寬還是渲染出來的。傳入的數(shù)據(jù)限制了數(shù)據(jù)展示區(qū)域的高和寬。
方法二:根據(jù)echarts容器的父容器的寬高為其賦值
首先介紹js獲取元素的寬高的方法:
var dom = document.getElementsByClassName('sec')[0];
var w1 = dom.style.width; // 只能獲取到內(nèi)聯(lián)樣式的屬性值
var w2 = dom.currentStyle.width; // 雖然支持全部三種設(shè)置樣式的方式,但是只支持IE
var w3 = window.getComputedStyle(dom).width; // 支持IE、Chrome、Firefox的全部三種樣式
var w4 = dom.getBoundingClientRect().width; // 同樣能獲取及時的尺寸,支持IE、Chrome、Firefox,只是獲取到的是數(shù)值不帶單位
const resizeMyChartContainer = function() {
// 無需再進(jìn)行數(shù)值計算的,可直接拿帶單位的屬性
const containerWidth = window.getComputedStyle(document.getElementsByClassName('app-main')[0]).width
const containerHeight = window.getComputedStyle(document.getElementsByClassName('app-main')[0]).height
// 需進(jìn)行數(shù)值計算的,拿不帶單位的屬性
const containerHeightWithoutUnit = document.getElementsByClassName('app-main')[0].getBoundingClientRect().height
// 百分比計算 并加單位
myChartContainer.style.height = containerHeightWithoutUnit * 0.65 + 'px'
myChartContainer.style.width = containerWidth
}
echarts自適應(yīng)屏幕寬度自動改變大小
在vue組件中在mouted鉤子里先調(diào)用初始化echarts的方法,然后再添加window監(jiān)聽事件resize,讓window監(jiān)控屏幕大小變化,從而用定時器setTimeout每隔100毫秒執(zhí)行echart.resize()事件。
注意this的指向,在外面從新定義this=this指向,還有初始化resizeTimer為空

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
websocket+Vuex實現(xiàn)一個實時聊天軟件
這篇文章主要利用websocked 建立長連接,利用Vuex全局通信的特性,以及watch,computed函數(shù)監(jiān)聽消息變化,并驅(qū)動頁面變化實現(xiàn)實時聊天,感興趣的可以了解一下2021-08-08
element的el-form和el-table嵌套使用實現(xiàn)
本文主要介紹了element的el-form和el-table嵌套使用實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
vue實現(xiàn)動態(tài)監(jiān)測元素高度
這篇文章主要介紹了vue實現(xiàn)動態(tài)監(jiān)測元素高度方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
vue2.x中的provide和inject用法小結(jié)
這篇文章主要介紹了vue2.x中的provide和inject用法小結(jié),本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12
Vue?uni-app框架實現(xiàn)上拉加載下拉刷新功能
uni-app是一個使用Vue.js(opens?new?window)開發(fā)所有前端應(yīng)用的框架,開發(fā)者編寫一套代碼,可發(fā)布到iOS、Android、Web(響應(yīng)式)、以及各種小程序(微信/支付寶/百度/頭條/飛書/QQ/快手/釘釘/淘寶)、快應(yīng)用等多個平臺2022-09-09
vue單向以及雙向數(shù)據(jù)綁定方式(v-bind和v-model的使用)
這篇文章主要介紹了vue單向以及雙向數(shù)據(jù)綁定方式(v-bind和v-model的使用),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
創(chuàng)建和運(yùn)行Vue.js項目方法demo
這篇文章主要為大家介紹了創(chuàng)建和運(yùn)行Vue.js項目方法demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
vue使用css-rcurlyexpected等less報錯問題
這篇文章主要介紹了vue使用css-rcurlyexpected等less報錯問題,具有很的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10

