vue监听div大小改变多个echart大小

1、安装插件

npm install element-resize-detector

2、引入
单页面引入:

 import elementResizeDetectorMaker from 'element-resize-detector'

main.js引入:

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

3、页面上使用

//chartBox4是外层盒子,我们就监控它的大小来判定是否需要重置图表
//多个的话子组件的id记得写成不同的
//就像我这样后缀1,2,3,4都可以,不然会识别出错
<div id="chartBox4"
       class="chart_box3"
       :style="{height:'300px',width:'100%'}">
       //这个chart就是我们的图表
    <div id="chart"/>
  </div>

4、methods钩子函数中加入以下两个方法

watchSize() {
        //这里获取节点,不然到方法里获取就麻烦了
      var chart = document.getElementById('chart')
      //这里this要定义一下,不然到监听里就会冲突
      const _this = this
      var erd = elementResizeDetectorMaker()
      //监听盒子的变化
      erd.listenTo(document.getElementById('chartBox4'), function (element) {
      //调用方法,重置chart大小
        _this.chartssize(chart)
      })
    },
chartssize(chart) {
//获取盒子的宽度跟高度,这里用clientWidth是为了将100%转换成px,然后赋值给chart的长宽
      chart.style.width = document.getElementById('chartBox4').clientWidth
      chart.style.height = document.getElementById('chartBox4').clientHeight
      //进行重置
      setTimeout(() => {
        this.chart.resize()
      }, 20)
    },

若是全局引用,watchSize里面的

 var erd = elementResizeDetectorMaker()
      //监听盒子的变化
      erd.listenTo(document.getElementById('chartBox4'), function (element) {
      //调用方法,重置chart大小
        _this.chartssize(chart)
      })

替换为

this.$erd.listenTo(
      document.getElementById("headquarters-analysisOperating"),
        function (element) {
          //调用方法,重置chart大小
              _this.chartssize();
         }
);

5、在mouted钩子函数中加入调用方法

mounted() {
//加入这条,不是只有这条
    this.watchSize()
  },
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 转载自:https://blog.csdn.net/Missbelover/article/details/882...
    天字一等阅读 5,457评论 0 10
  • 什么是Vue.js Vue.js是目前最火的一个前端框架,React是最流行的一个前端框架,(React除了开发网...
    EEEEsun阅读 3,882评论 0 1
  • vue的核心是什么? Vue 的核心设计理念可以概括为以下 5 个关键要素,这些要素共同构成了 Vue 的独特优势...
    Aniugel阅读 13,313评论 3 21
  • 1.vue生命周期有哪些,在每个生命周期都做什么事情? vue实例从创建到销毁的整个过程,总共有8个生命钩子函数 ...
    皓皓102阅读 4,114评论 0 1
  • 1、active-class是哪个组件的属性?嵌套路由怎么定义?答:vue-router模块的router-lin...
    jane819阅读 5,707评论 0 15