Element圖表初始大小及窗口自適應(yīng)實現(xiàn)
最近在做一個輪播圖,使用的是element的Carousel走馬燈,每一個走馬燈里是eachrts圖,開始頁面加載的時候發(fā)現(xiàn)echarts圖并不能自適應(yīng),開始以為是走馬燈的問題,后來發(fā)現(xiàn)不是
不知道大家在用echarts的時候有沒有遇到這種情況:
最開始盛放圖表的容器是隱藏(或者tab切換)的,然后再顯示的時候,里面echarts圖表就沒用初始大小了。比如我遇到的這種:

有童鞋這會兒估計看出原因了:因為元素最初隱藏,再顯示之后沒有自動變化寬度,所以echarts圖表沒有初始寬高,官方文檔的說法:

請注意:這個寬度在一些情況下設(shè)置百分比 是沒有作用的,所以得設(shè)置為具體數(shù)字或者用js賦值,類似這種:
$('main').style.width = (document.body.clientWidth-300)*0.6+'px';
P.S:這里沒說高度是因為如果不給容器固定高度,圖表是完成不顯示的(高度為0的容器肯定不會顯示哦)
那么如果想設(shè)置echart圖表隨窗口的縮放變化呢?以下兩種寫法都可以:
第一種:
window.onresize = myChart.resize; // .resize后不用加括號哦,一般如果window resize的時候不設(shè)置其他,可以這樣寫
第二種:
window.onresize = function () {
this.myChart.resize();
// .resize后加括號哦,這里還可以寫其他的事件
};
echarts官方文檔寫的很詳細(xì)哦,需要的童鞋自己去翻閱。
具體到我的代碼,我是這樣實現(xiàn)的,因為我的容器是百分比寫的,所以我的實現(xiàn)方式如下:

即是dom節(jié)點渲染以后,調(diào)用echarts實例的resize()方法;
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Vue3?封裝?Element?Plus?Menu?無限級菜單組件功能的詳細(xì)代碼
本文分別使用?SFC(模板方式)和?tsx?方式對?Element?Plus?*el-menu*?組件進(jìn)行二次封裝,實現(xiàn)配置化的菜單,有了配置化的菜單,后續(xù)便可以根據(jù)路由動態(tài)渲染菜單,對Vue3?無限級菜單組件相關(guān)知識感興趣的朋友一起看看吧2022-09-09
Vue實現(xiàn)左右菜單聯(lián)動實現(xiàn)代碼
這篇文章主要介紹了Vue實現(xiàn)左右菜單聯(lián)動實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-08-08
vue中利用prop進(jìn)行父子通信時的注意事項總結(jié)
這篇文章主要給大家介紹了關(guān)于vue中利用prop進(jìn)行父子通信時的注意事項,文中通過實例介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2022-01-01
elementUI使用el-upload上傳文件寫法及避坑總結(jié)(上傳圖片/視頻到本地/服務(wù)器及回顯+刪除)
upload上傳是前端開發(fā)很常用的一個功能,下面這篇文章主要給大家介紹了關(guān)于elementUI使用el-upload上傳文件寫法及避坑的相關(guān)資料,包括上傳圖片/視頻到本地/服務(wù)器及回顯+刪除,需要的朋友可以參考下2023-03-03

