window.external.notify() 与 UglifyJS 压缩优化冲突

本文探讨了使用UglifyJS压缩JavaScript代码时遇到的问题,即压缩后的代码无法正常调用window.external.notify()方法。通过对比压缩前后代码的变化,分析了问题可能的原因,并提出了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

近期研究了一下 UglifyJs 对 JS 代码的压缩,发现 UglifyJS 压缩后,无法调用 window.external.notify() 方法,JS 代码如下:

function MyNotify () {
    try{
        alert("Notify");
        window.external.notify("Notify");
    } catch (e){
        alert(e.message);
    }
}

function MyNotifyCompressed(){
    try {
        alert("Notify"), window.external.notify("Notify");
    } catch (e) {
        alert(e.message);
    }
}

UglifyJS 在压缩 JS 代码时,压缩选项(-c)中有这么一个参数:

sequences -- join consecutive simple statements using the comma operator

此选项默认是开启状态。当此选项处于开启状态时,UglifyJS 将会把多行代码压缩为一行并使用逗号进行分隔。压缩后,利用 InvokeScript() 调用 MyNotifyCompressed() 函数,系统将提示:

Object doesn't support this action

window.external.notify() 方法无法正常使用,则在程序中的一些逻辑无法正常处理。到底为什么无法调用这个方法呢?暂时也不大明白,可能是作用域出现问题了。

如果使用逗号相连导致不能直接调用 window.external.notify() 的话,那还是把它单独封装成一个函数好了。

转载于:https://www.cnblogs.com/blastmann/p/external-notify-cant-use-with-uglifyjs-compressor.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值