关于ES2020语法2345加速浏览器不兼容问题

文章讲述了在已上线的项目中,遇到2345加速浏览器无法打开部分页面的问题,报错为UncaughtSyntaxError:Unexpectedtoken,原因是项目使用了ES2020的新特性如OptionalChaining(?.)和NullishCoalescing(??),而2345浏览器的某些内核可能不支持这些语法。作者提供了修改代码以避免此类问题的示例。
摘要由CSDN通过智能技术生成

关于ES2020语法2345加速浏览器不兼容问题

项目已经上线,谷歌浏览器,360浏览器,火狐浏览器等好几个浏览器都测试过没问题,没过几天用户反馈有几个页面在2345加速浏览器打不开,报错如下:

Uncaught SyntaxError: Unexpected token ? 

有经验的一眼就看出是语法报错,但是2345加速浏览器是由Chrome内核与IE内核双核加持打造,正常来讲在谷歌浏览器能支持,2345加速浏览器也支持。

代码中使用了ES2020的语(?? 和 ?.),不懂这个语法的小伙伴可以百度下。因为我们的项目没有使用ES6转ES5,所以报了语法错误,具体为什么2345加速浏览器不支持ES2020的语法我还不知道,有知道的大佬麻烦赐教一下。

示例1const cengciSearchCache = JSON.parse(sessionStorage.getItem('bk_cengci_search_data')) ?? {}  // 报错
改为:
const cengciSearchCache = JSON.parse(sessionStorage.getItem('bk_cengci_search_data')) ?        JSON.parse(sessionStorage.getItem('bk_cengci_search_data')) : {};

示例2this.initAllck('', attached, this.searchList.qidalei[oneFlIndex]?.erjidaleit);
改为:
this.initAllck('',attached,this.searchList.qidalei[oneFlIndex] ? this.searchList.qidalei[oneFlIndex].erjidalei : undefined);

注意避坑,否则两个小时就没了。。。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值