Dodałem następujące PolyFill do Array
na początku mojego projektu:Dodawanie funkcji do Array.prototype w IE skutkuje tym pchane w każdej tablicy jako element
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;
};
}
To działa perfekcyjnie w Chrome i Firefox, Internet Explorer, ale na 11, funkcja ta jest rzeczywiście pchnął w każdym Array
jako element niego i mogę nawet uzyskać dostęp to lubią:
var a = [];
a[0]();
to throwin g wszelkiego rodzaju wyjątki w IE z funkcjami takimi jak .forEach
, gdzie spodziewam się pewnych danych i ta funkcja zostanie znaleziona.
Oto zrzut ekranu z narzędzi IE deweloperskich, w tym przypadku, ta tablica powinna mieć tylko 2 elementy, zamiast 3.
I tak powinno być, z Chrome. W rzeczywistości uważam, że nawet rzeczywista zawartość jest błędna, ale jeszcze się tam nie dostałem (powinna to być tablica zawierająca tablice o długości 2).
Jak JavaScript nadal zachowują się tak źle w IE11 i jak mogę poprawnie dodać tę funkcję do prototype
zamiast w każdym Array
przykład?
To wspaniała odpowiedź i działa! Ostatnie pytanie: wziąłem tę polyfill z Mozilla Developer's Network (https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find#Polyfill) i wszystkie ich polyfills używają to samo podejście do bezpośredniego dodawania funkcji do prototypu obiektu (inny przykład: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/String/startsWith#Polyfill). Czy powinienem go całkowicie unikać i zawsze używać 'defineProperty'? Czy to będzie tylko problem w 'Array'? –
Osobiście użyłbym 'defineProperty()', ale jeśli próbujesz sprawić, żeby rzeczy działały na IE8 lub starszym, napotkasz trudności. Zawsze możesz wrócić do zwykłego dodawania właściwości do prototypu, jeśli 'defineProperty' nie działa. – Pointy
@WillP. tak, przed IE9 natywne prototypy w IE nie mogły być modyfikowane. – Pointy