解决IE报错[vue router]Failed to resolve async component default:strict 模式下不允许分配到只读属性...

  之前遇到过一个奇怪的问题,在其他浏览器下一切正常,但在万恶的IE下,却一直不行。

  具体问题场景就是:比如orderDetail页面出现问题,那么只要是路由跳转的,点第1次无法跳转,必须得点第2次才可以跳转,但是跳转过去之后,页面也是一片空白,不加载路由页面。然后控制台报错:strict 模式下不允许分配到只读属性。

  所以我往这方面搜索,在网上看到一些相关信息

  IE中JavaScript异常提示:strict 模式下不允许分配到只读属性。报异常的代码如下:

document.getElementById("mapLayer").style = "width: 98%;height:98%;";

  解决方法如下: 将css属性拆分开依次设置属性值即可。

document.getElementById("mapLayer").style.width = "98%";
document.getElementById("mapLayer").style.height = "98%";

  注:在这严格模式下xxx.style会被认定为只读属性,所以在IE中报错。

  但是,我在我的代码里找了几圈都没有找到类似的只读属性。

  没办法,只能使用傻办法一层一层排查。最后发现把orderDetail页面里的内容全部换成其他页面,发现是可以正常的,由此可以确定,问题就出在该orderDetail页面里,然后再到orderDetail页面里一层一层排查。发现问题出在这里

import QRCode from 'qrcode'

// 动态生成二维码
useqrcode () {
  let canvas = document.getElementById('canvas')
  let _this = this
        QRCode.toCanvas(canvas, this.qrcode, function (error) {
          if (error) {
            _this.$message({
              message: '二维码生成失败,请重新支付',
              type: 'error'
            })
          }
        })
      },

  关键是不知道为什么引入QRCode,然后画图会导致IE报这种错,对IE实在是蛋疼,没办法只能修改这地方

  解决方案:换 qriously 生成二维码

<qriously class="qrcode" :value="qrcode" :size="150"/>

  修改之后一切正常了。

转载于:https://www.cnblogs.com/goloving/p/10845508.html

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值