【发布时间】:2016-09-27 19:13:22
【问题描述】:
我在项目开始时将以下 polyfill 添加到 Array:
if (!Array.prototype.find) {
Array.prototype.find = function(predicate) {
if (this === null) {
throw new TypeError('Array.prototype.find called on null or undefined');
}
if (typeof predicate !== 'function') {
throw new TypeError('predicate must be a function');
}
var list = Object(this);
var length = list.length >>> 0;
var thisArg = arguments[1];
var value;
for (var i = 0; i < length; i++) {
value = list[i];
if (predicate.call(thisArg, value, i, list)) {
return value;
}
}
return undefined;
};
}
这在 Chrome 和 Firefox 中运行良好,但在 Internet Explorer 11 上,此功能实际上是在每个 Array 中推送作为它的一个元素,我什至可以像这样访问它:
var a = [];
a[0]();
这会在 IE 中使用 .forEach 之类的函数引发各种异常,我期望在其中找到一些数据并找到此函数。
这是 IE 开发者工具的截图,在这种情况下,这个数组应该只有 2 个元素,而不是 3 个。
这就是它应该的样子,来自 Chrome。事实上,我相信即使实际的内容是错误的,但我还没有到达那里(它应该是一个包含长度为 2 的数组的数组)。
JavaScript 如何在 IE11 中仍然表现得如此错误,我如何才能将此函数正确添加到 prototype 而不是在每个 Array 实例中?
【问题讨论】:
标签: javascript internet-explorer-11