Maison  >  Article  >  interface Web  >  Pourquoi `Array.indexOf()` échoue-t-il dans IE8 et comment peut-il être corrigé ?

Pourquoi `Array.indexOf()` échoue-t-il dans IE8 et comment peut-il être corrigé ?

DDD
DDDoriginal
2024-11-21 00:36:17827parcourir

Why Does `Array.indexOf()` Fail in IE8, and How Can It Be Fixed?

La fonction Array.indexOf() échoue dans IE8

La fonction indexOf(), utilisée pour vérifier l'index d'un élément dans un tableau , présente des défis dans les versions d'Internet Explorer (IE) antérieures à 9. Plus précisément, dans IE8, cette fonction ne fonctionne pas comme prévu, laissant les développeurs perplexe.

Pour retracer la cause première, considérez la fonction suivante, qui est fonctionnelle dans les navigateurs tels qu'Opera, Firefox et Chrome :

function CheckMe() {
    var allowed = new Array('docx','xls','xlsx', 'mp3', 'mp4', '3gp', 'sis', 'sisx', 'mp3', 'wav', 'mid', 'amr', 'jpg', 'gif', 'png', 'jpeg', 'txt', 'pdf', 'doc', 'rtf', 'thm', 'rar', 'zip', 'htm', 'html', 'css', 'swf', 'jar', 'nth', 'aac', 'cab', 'wgz');
    var fileinput=document.getElementById('f');
    var ext = fileinput.value.toLowerCase().split('.');
    
    if (allowed.indexOf(ext[1]) == -1) {...

L'erreur se produit lorsque la fonction tente de exécutez l'instruction conditionnelle if (allowed.indexOf(ext[1]) == -1). Dans IE8, indexOf() n'est pas pris en charge pour les tableaux, ce qui entraîne l'échec du code.

Pour résoudre ce problème, le correctif suivant peut être implémenté :

if (!Array.prototype.indexOf)
{
  Array.prototype.indexOf = function(elt /*, from*/)
  {
    var len = this.length >>> 0;

    var from = Number(arguments[1]) || 0;
    from = (from < 0)
         ? Math.ceil(from)
         : Math.floor(from);
    if (from < 0)
      from += len;

    for (; from < len; from++)
    {
      if (from in this &&
          this[from] === elt)
        return from;
    }
    return -1;
  };
}

Ce correctif ajoute le indexOf () au prototype Array s'il n'est pas présent, en ciblant spécifiquement IE8 ou version antérieure là où il est manquant. En incorporant ce correctif, la fonction CheckMe() fonctionnerait comme prévu, résolvant ainsi le problème dans IE8.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn