echarts实现宽高自适应,vue中解决window.onresize失效

echarts实现宽高自适应

<template>
	<div id="main" style="width:100%;height:300px;"></div>
</template>
<script>
export default {
data() {
        return {
        	myChart: '',
        	isinit: false, // 是否已初始化过
        	screenWidth: document.body.clientWidth,
            screenHeight: document.body.clientHeight,
        }
 },
 methods: {
	changeEcharts(){
		if(!this.isinit){
          var chartDom = document.getElementById('main');
             this.myChart = this.$echarts.init(chartDom);
             var option;
         }
        option = {
		  xAxis: {
		    type: 'category',
		    data: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun']
		  },
		  yAxis: {
		    type: 'value'
		  },
		  series: [
		    {
		      data: [120, 200, 150, 80, 70, 110, 130],
		      type: 'bar'
		    }
		  ]
		};
		
		option && this.myChart.setOption(option);
}
},
 watch: {
 		// 监听窗口宽度变化时触发
        screenWidth() {
        	this.isinit = true
        	// resize()重新绘制
            this.myChart.resize()
        },
        // 监听窗口高度变化时触发
        screenHeight(){
            this.isinit = true
            this.myChart.resize()
        }
    },
 mounted() {
	var that = this;
        window.onresize = () => {
            return (() => {
                window.screenWidth = document.body.clientWidth
                that.screenWidth = window.screenWidth
                window.screenHeight = document.body.clientHeight
                that.screenHeight = window.screenHeight
            })()
        }
}
}
</script>

解决window.onresize失效

解决方法:将window.onresize换成window.addEventListener(‘resize’, () => {})

window.addEventListener('resize', () => {
            window.screenWidth = document.body.clientWidth
            that.screenWidth = window.screenWidth
            window.screenHeight = document.body.clientHeight
            that.screenHeight = window.screenHeight
        })
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值