目录
  • mounted中window.onresize不生效
    • 解决方案
  • window.onresize被覆盖问题
    • 解决方案

mounted中window.onresize不生效

在vue开发中,因为引用的父组件和子组件都使用了window.onresize以至于一个window.onresize失效。

解决方案

可以采用下面的方式

window.onresize = () => this.screenWidth = window.innerWidth 
// 改为以下写法
window.addEventListener('resize', () => this.screenWidth = window.innerWidth, false)

window.onresize被覆盖问题

多个子组件中都存在window.onresize时,后一个会把前一个覆盖,导致之前的onresize都失效。

    const _this = this
    window.onresize = function() {
      if (_this.chart) {
        _this.chart.resize()
      }
    }

解决方案

使用addEventListener方法添加监听

    const _this = this
    window.addEventListener('resize', () => {
      if (_this.chart) {
        _this.chart.resize()
      }
    })

以上为个人经验,希望能给大家一个参考,也希望大家多多支持。

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。