web-dev-qa-db-ja.com

「オブジェクトはIE」のプロパティまたはメソッド「find」をサポートしていません

<!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でエラーが発生します。エラーメッセージ:

Object doesn't support property or method 'find'

56
GOPAL YADAV

JavaScriptのarray.find()メソッドを使用しています。これは標準のJSであり、jQueryとは関係がないことに注意してください。実際、問題のコード全体ではjQueryをまったく使用していません。

array.find()のドキュメントは次の場所にあります: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/find

このページの一番下までスクロールすると、ブラウザのサポート情報が表示され、IEがこのメソッドをサポートしていないことが表示されます。

皮肉なことに、これを回避する最善の方法は、jQueryを使用することです。jQueryには、すべてのブラウザーでサポートされている同様の機能があります。

36
Simba

前述のとおり、array.find()はIEではサポートされていません。

ただし、ここでポリフィルについて読むことができます:

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find#Polyfill

このメソッドはECMAScript 2015仕様に追加されており、一部のJavaScript実装ではまだ利用できない場合があります。ただし、次のスニペットを使用して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;
    }
  });
}
30
Ogglas

Array.prototype.findはIEのどのバージョンでもサポートされていません

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find

24
Carl Markham

これは回避策です。検索の代わりにフィルターを使用できます。ただし、filterは一致するオブジェクトの配列を返します。 findは、配列内の最初の一致のみを返します。したがって、次のようにフィルターを使用しないのはなぜですか。

data.filter(function (x) {
         return x.Id === e
    })[0];
21
Mahib