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 中的“对象不支持属性或方法‘查找’”的主要内容,如果未能解决你的问题,请参考以下文章

dojo IE 中的“对象不支持此操作”

flex 不支持 IE11 中的计算

IE8 不支持 extjs4 中的斜体标签

IE10以下兼容H5中的placeholder

IE 在引用 CSS 文件时不支持基本元素中的相对路径

ie9不支持vue的v-for循环怎么处理