欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue使用element-resize-detector監(jiān)聽元素寬度變化方式

 更新時間:2022年12月09日 11:07:59   作者:Agwenbi  
這篇文章主要介紹了vue使用element-resize-detector監(jiān)聽元素寬度變化方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

使用element-resize-detector監(jiān)聽元素寬度變化

如圖,當我們切換左側菜單展示效果的時候,右側內容會對應變寬,但此時的echarts并不能執(zhí)行自適應效果,這是因為切換菜單展示效果并沒有觸發(fā)window.onresize,所以為解決類似此問題,我們可使用element-resize-detector

1、引入element-resize-detector,npm install element-resize-detector --save

2、在對應位置上引入即可

let elementResizeDetectorMaker = require("element-resize-detector");
//監(jiān)聽元素變化
let erd = elementResizeDetectorMaker();
let that = this;
erd.listenTo(document.getElementById("bar"), function (element) {
    that.$nextTick(function () {
        //使echarts尺寸重置
        that.myEcharts.resize();
    })
})
//監(jiān)聽元素變化

PS:如果在改變寬度過程中存在動畫效果,此時我們可以使用防抖,使在動畫結束后再resize,這樣做的好處是避免在動畫過程中不斷進行resize,造成界面卡頓,影響性能

節(jié)流與防抖代碼見:http://www.dbjr.com.cn/article/269597.htm

<template>
    <div class="page">
        <div id="bar" class="echarts"></div>
    </div>
</template>
 
<script>
    let elementResizeDetectorMaker = require("element-resize-detector");
    import {debounce} from 'utils.js';
    export default {
        name:'page',
        mounted(){
            let erd = elementResizeDetectorMaker();
            let that = this;
            erd.listenTo(document.getElementById("bar"), debounce(this.resizeFunc))
        },
        methods:{
            resizeFunc(element){
                console.log(element);//element元素信息
                that.$nextTick(function () {
                    //使echarts尺寸重置
                    that.myEcharts.resize();
                })
            }
        }
    }
</script>
 
<style lang="scss" scoped>
.page{
    width:100%;
    height:100%;
    .echarts{
        width:100%;
        height:100%;
    }
}
</style>

全局element-resize-detector監(jiān)聽DOM元素

解決方案 

第一步:通過npm install element-resize-detector獲取elementResizeDetectorMaker

npm install element-resize-detector

第二步:將依賴引入import elementResizeDetectorMaker from ‘element-resize-detector’

import ElementResizeDetectorMaker from "element-resize-detector"
Vue.prototype.$erd = ElementResizeDetectorMaker()

第三步:使用

? ? ? ? ? this.$erd.listenTo(document.getElementById("chinaMapChart"), (element)=>{
? ? ? ? ? ? this.resize()
? ? ? ? ? })

如果不使用Lambda表達式作為監(jiān)聽器,會出現(xiàn)不能獲取data和methods的情況,具體原因參考JavaScript高級教程

解決方案:

let that = this;
this.$erd.listenTo(document.getElementById("bar"), function (element) {
? ? that.$nextTick(function () {
? ? ? ? //使echarts尺寸重置
? ? ? ? that.myEcharts.resize();
? ? })
})
? ? ? ? ? ? //監(jiān)聽元素變化

總結

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue項目運行或打包時,頻繁內存溢出情況問題

    vue項目運行或打包時,頻繁內存溢出情況問題

    這篇文章主要介紹了vue項目運行或打包時,頻繁內存溢出情況的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue2.0實現(xiàn)簡單分頁及跳轉效果

    Vue2.0實現(xiàn)簡單分頁及跳轉效果

    這篇文章主要為大家詳細介紹了Vue2.0實現(xiàn)簡單數(shù)據(jù)分頁,及頁數(shù)的跳轉效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-07-07
  • vue實現(xiàn)pdf導出解決生成canvas模糊等問題(推薦)

    vue實現(xiàn)pdf導出解決生成canvas模糊等問題(推薦)

    最近公司項目需要,利用vue實現(xiàn)pdf導出,從而保存到本地打印出來,說起來好像也很容易,具體要怎么實現(xiàn)呢?下面小編給大家?guī)砹藇ue實現(xiàn)pdf導出解決生成canvas模糊等問題,需要的朋友參考下吧
    2018-10-10
  • Vue實現(xiàn)用戶登錄及token驗證

    Vue實現(xiàn)用戶登錄及token驗證

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)用戶登錄及token驗證,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • vuex通過getters訪問數(shù)據(jù)為undefined問題及解決

    vuex通過getters訪問數(shù)據(jù)為undefined問題及解決

    這篇文章主要介紹了vuex通過getters訪問數(shù)據(jù)為undefined問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue3中使用百度地圖的簡單步驟

    vue3中使用百度地圖的簡單步驟

    最近項目要用到百度地圖api,好久沒用到地圖,就百度了一番,下面這篇文章主要給大家介紹了關于vue3中使用百度地圖的簡單步驟,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-06-06
  • vue3+ts項目搭建的實現(xiàn)示例

    vue3+ts項目搭建的實現(xiàn)示例

    這篇文章主要介紹了vue3+ts項目搭建的實現(xiàn)示例,本文目的在于記錄自己項目框架搭建的過程,通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2024-03-03
  • vue?+?electron應用文件讀寫操作

    vue?+?electron應用文件讀寫操作

    這篇文章主要介紹了vue?+?electron應用文件讀寫操作,如果要制作的應用并不復雜,完全可以將數(shù)據(jù)存儲在本地文件當中,然后應用就可以通過這些文件進行數(shù)據(jù)的讀寫,需要的朋友參考下吧
    2022-06-06
  • Vue中的基礎過渡動畫及實現(xiàn)原理解析

    Vue中的基礎過渡動畫及實現(xiàn)原理解析

    這篇文章主要介紹了Vue中的基礎過渡動畫原理解析,需要的朋友可以參考下
    2018-12-12
  • vue不操作dom實現(xiàn)圖片輪播的示例代碼

    vue不操作dom實現(xiàn)圖片輪播的示例代碼

    這篇文章主要介紹了vue不操作dom實現(xiàn)圖片輪播的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12

最新評論