IE 中的“对象不支持属性或方法‘查找’”
Posted
技术标签:
【中文标题】IE 中的“对象不支持属性或方法‘查找’”【英文标题】:"Object doesn't support property or method 'find'" in IE 【发布时间】:2016-10-13 19:12:21 【问题描述】:<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
<title></title>
<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.10.2/jquery.min.js"></script>
<script>
$(document).ready(function ()
var data = [
"Id": "SWE",
"Country": "Sweden",
"Population": 9592552
,
"Id": "NOR",
"Country": "Norway",
"Population": 5084190
];
function display(e)
alert("E" + e);
var countryData = data.find(function (element, index, array)
return element.Id === e;
);
alert(countryData.Population);
display('SWE');
);
</script>
</head>
</html>
上面发布的代码在 Firefox 和 Chrome 上运行正常,但在 Internet Explorer 中出现错误。错误信息:
对象不支持“查找”属性或方法
【问题讨论】:
您使用什么版本的 IE 进行测试?还有,是标准模式、兼容模式还是怪癖模式? 嗨@Simba,我使用的是 IE 版本 11.0.9660.18321 检查哪些浏览器支持哪些功能,caniuse.com很有帮助,仅供参考。 developer.mozilla.org/en-US/docs/Web/javascript/Reference/… 【参考方案1】:这是一个解决方法。您可以使用过滤器代替查找;但 filter 返回一个匹配对象的数组。 find
只返回数组中的第一个匹配项。那么,为什么不使用以下过滤器;
data.filter(function (x)
return x.Id === e
)[0];
【讨论】:
最近在一个项目中遇到这个问题,普遍的共识是使用@babel/polyfill。走了那条路,发现 polyfill 实际上产生了一些奇怪的错误,所以我们不得不把它拉出来。但是,该解决方案具有很强的针对性,解决了该问题而没有任何副作用。简单,干净,直截了当。谢谢! 对于那些需要保持 IE11 兼容的最简单、最干净、等效的解决方法,谢谢! filter() 和 find() 函数之间的主要区别是 filter() 遍历所有数组,而 find() 只是第一次出现。此解决方法可能会产生一些性能问题。【参考方案2】:如前所述,IE 不支持 array.find()
。
但是,您可以在此处阅读有关 Polyfill 的信息:
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find#Polyfill
此方法已添加到 ECMAScript 2015 规范中,并且 可能尚未在所有 JavaScript 实现中都可用。然而, 您可以使用以下 sn-p 填充 Array.prototype.find:
代码:
// https://tc39.github.io/ecma262/#sec-array.prototype.find
if (!Array.prototype.find)
Object.defineProperty(Array.prototype, 'find',
value: function(predicate)
// 1. Let O be ? ToObject(this value).
if (this == null)
throw new TypeError('"this" is null or not defined');
var o = Object(this);
// 2. Let len be ? ToLength(? Get(O, "length")).
var len = o.length >>> 0;
// 3. If IsCallable(predicate) is false, throw a TypeError exception.
if (typeof predicate !== 'function')
throw new TypeError('predicate must be a function');
// 4. If thisArg was supplied, let T be thisArg; else let T be undefined.
var thisArg = arguments[1];
// 5. Let k be 0.
var k = 0;
// 6. Repeat, while k < len
while (k < len)
// a. Let Pk be ! ToString(k).
// b. Let kValue be ? Get(O, Pk).
// c. Let testResult be ToBoolean(? Call(predicate, T, « kValue, k, O »)).
// d. If testResult is true, return kValue.
var kValue = o[k];
if (predicate.call(thisArg, kValue, k, o))
return kValue;
// e. Increase k by 1.
k++;
// 7. Return undefined.
return undefined;
);
【讨论】:
如果您投反对票,请说明原因。否则很难改善答案。【参考方案3】:您正在使用 JavaScript array.find()
方法。请注意,这是标准 JS,与 jQuery 无关。事实上,你在问题中的整个代码根本没有使用 jQuery。
您可以在此处找到array.find()
的文档:https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/find
如果你滚动到这个页面的底部,你会注意到它有浏览器支持信息,你会看到它说 IE 不支持这种方法。
具有讽刺意味的是,您最好的解决方法是使用 jQuery,它确实具有所有浏览器都支持的类似功能。
【讨论】:
第二种选择是滚动你自己的 for 循环,如果由于某些奇怪的原因你不被允许使用 jQuery 或者只是做array.filter()[0]
在“具有讽刺意味的是,您最好的解决方法是使用 jQuery”:)【参考方案4】:
任何版本的 IE 都不支持Array.prototype.find
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find
【讨论】:
并且页面提供了一个有用的polyfill Polyfill 很好用,它会检查prototype.find 是否未定义,然后将属性定义为Array.prototype: Object.defineProperty(Array.prototype, 'find', 谢谢!【参考方案5】:我通过添加以下 polyfill 解决了同样的问题:
<script src="https://cdn.polyfill.io/v3/polyfill.min.js?features=default,Array.prototype.includes,Array.prototype.find"></script>
polyfill 是一段代码(通常是 Web 上的 JavaScript),用于在原生不支持它的旧浏览器上提供现代功能。
希望有人觉得这很有帮助。
【讨论】:
【参考方案6】:只是为了提及underscore's find方法在IE中没有问题。
【讨论】:
【参考方案7】:IE 不支持Array.prototype.find
如果您不想添加 polyfill,可以使用 array.filter(filterFunction)[0]
这是一个不错的替代选择:
var idToMatch = 2
var array = [ id: 1 , id: 2 , id: 3 ]
function filterArray (item)
return item.id === idToMatch;
var matchingObject =
// vv The important bit vv
array.filter(filterArray)[0]
这个想法归功于Rok Burgar,但他没有发布作为答案,只是作为评论。
【讨论】:
为什么是负面的?? 我希望我知道 :(【参考方案8】:对 Microsoft 浏览器的 Array.find
方法支持始于 Edge。
W3Schools compatibility table 表示支持从版本 12 开始,而Can I Use compatibility table 表示支持在版本 12 和 14 之间未知,从版本 15 开始正式支持。
【讨论】:
IE12 不存在。您正在查看的带有蓝色“e”标志的浏览器现在称为 Edge,与它的前身 IE 有很大不同。以上是关于IE 中的“对象不支持属性或方法‘查找’”的主要内容,如果未能解决你的问题,请参考以下文章