"Объект не поддерживает свойство или метод" find "в IE
<!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'
Ответы
Ответ 1
Вы используете метод JavaScript array.find()
. Обратите внимание, что это стандартный JS и не имеет ничего общего с jQuery. На самом деле, весь ваш код в вопросе вообще не использует jQuery.
Вы можете найти документацию для array.find()
здесь: https://developer.mozilla.org/en/docs/Web/JavaScript/Reference/Global_Objects/Array/find
Если вы перейдете к нижней части этой страницы, вы заметите, что у нее есть информация о поддержке браузера, и вы увидите, что она заявляет, что IE не поддерживает этот метод.
По иронии судьбы, наилучшим способом для этого было бы использовать jQuery, который имеет аналогичную функциональность, которая поддерживается во всех браузерах.
Ответ 2
Как уже упоминалось, array.find()
не поддерживается в IE.
Однако вы можете прочитать о Polyfill здесь:
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;
}
});
}
Ответ 3
Вот работа вокруг. Вы можете использовать фильтр вместо поиска; но фильтр возвращает массив совпадающих объектов. find
только возвращает первое совпадение внутри массива. Итак, почему бы не использовать фильтр следующим образом;
data.filter(function (x) {
return x.Id === e
})[0];
Ответ 4
Array.prototype.find
не поддерживается ни в одной версии IE
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find
Ответ 5
Просто с целью упоминания подчеркивания метод find работает в IE без проблем.
Ответ 6
Я решил ту же проблему, добавив polyfill следующее:
<script src="https://cdn.polyfill.io/v3/polyfill.min.js?features=default,Array.prototype.includes,Array.prototype.find"></script>
Полифилл - это фрагмент кода (обычно JavaScript в Интернете), используемый для обеспечения современных функций в старых браузерах, которые изначально не поддерживают его.
Надеюсь, кто-то поможет
Ответ 7
Array.find
метода Array.find
для браузеров Microsoft началась с Edge.
В таблице совместимости W3Schools указано, что поддержка началась в версии 12, а в таблице совместимости " Могу я использовать" говорится, что поддержка была неизвестна между версиями 12 и 14, и официально поддерживается начиная с версии 15.