Vidorra

Vidorra

主站:https://blog.vidorra.life

解决浏览器端 globalThis is not defined 报错

阅读原文

今日开发时,生产运维人员上报说页面打开一片空白,无法进入系统。排查一下发现是我的print-template-designer报的错,报了一个 globalThis is not defined。

其实之前好像印象中也遇到过此类错误,一般就是浏览器版本太低了。

上 Can I Use 查一下,发现 globalThis 在 chrome70 版本之前都不支持的。

image

那么解决方法就俩:

  • 让客户升级浏览器版本

  • 前端升级下,兼容下低版本

    最后还是让客户先升级浏览器版本了,win7 系统用最新版 108 就好了。(话说今年 chrome 停止支持 win7 了,108 应该是最后一个版本)

    另外代码层面怎么解决呢?只需要在 head 添加下面的代码即可。

<head>
  <script>
    this.globalThis || (this.globalThis = this)
  </script>
</head>

再有就是了解下 globalThis 是什么的问题:

加载中...
此文章数据所有权由区块链加密技术和智能合约保障仅归创作者所有。