Vue监听dom元素发生变化(用于echarts图表自适应屏幕)

1、下载依赖包
npm install element-resize-detector
2、在组件内引入依赖
var elementResizeDetectorMaker = require("element-resize-detector")
3、加载图表
<div id="warnstatistics"
           ref="typeEchart">
</div>
initEcharts(){
	option = {
    xAxis: {
        type: 'category',
        data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
    },
    yAxis: {
        type: 'value'
    },
    series: [{
        data: [150, 230, 224, 218, 135, 147, 260],
        type: 'line'
    }]
	}
		// 若不为空,则释放图表实例
      if (this.myEchart  != null && this.myEchart != "" && this.myEchart != undefined) {
        this.myEchart.dispose()
      }
      this.myEchart = echarts.init(this.$refs.typeEchart)
      this.myEchart.setOption(option)
}

4、mounted中监听加载图表的dom元素
mounted(){
	this.resizeEchart ()
}
methods:{
	resizeEchart () {
      var erd = elementResizeDetectorMaker()
      erd.listenTo(document.getElementById("warnstatistics"), element => {
        // 重置图表
        this.myEchart? this.myEchart.resize() : ''
      })
    }
}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值