【发布时间】:2017-01-07 03:29:04
【问题描述】:
在我帮助维护的代码库中,存在这种形式的函数(为简洁起见):
function setListeners(enable) {
const fn = enable ? document.body.addEventListener : document.body.removeEventListener;
fn('click', foo);
fn('MyCustomEvent', bar);
}
IE11 抛出Illegal Invocation,而其他浏览器工作正常。另一个维护者将功能切换为这种形式:
function setListeners(enable) {
const fn = enable ? document.body.addEventListener : document.body.removeEventListener;
fn.call(document.body, 'click', foo);
fn.call(document.body, 'MyCustomEvent', bar);
}
现在它可以在 IE11 中运行,但不能在 Chrome 中运行。我们已经为 CustomEvent 提供了一个 polyfill(如图所示隐含使用),但是还有什么阻止了这个函数跨浏览器?
【问题讨论】:
-
你肯定需要
.call方法,那么在 Chrome 中失败的原因是什么? -
由于第二个版本应该可以工作,问题可能出在代码的其他地方。所以你需要展示更多的代码。
标签: javascript google-chrome ecmascript-6 internet-explorer-11