2011-08-22 15 views
26

Esta es la línea:¿Por qué no funciona .filter() en Internet Explorer 8?

songs = songs.filter(function (el) { 
    return el.album==album; 
}); 

Este es el error:

Object doesn't support this property or method

Esto funciona al 100% bien en Chrome. ¿Que esta pasando?

+0

he publicado mi respuesta antes de ver a Paul. ¿Son canciones una matriz o un objeto jQuery? – Dennis

Respuesta

64

Array.filter() no está incluido en el IE hasta la versión 9.

Usted puede usar esto para ponerlo en práctica:

if (!Array.prototype.filter) 
{ 
    Array.prototype.filter = function(fun /*, thisp */) 
    { 
    "use strict"; 

    if (this === void 0 || this === null) 
     throw new TypeError(); 

    var t = Object(this); 
    var len = t.length >>> 0; 
    if (typeof fun !== "function") 
     throw new TypeError(); 

    var res = []; 
    var thisp = arguments[1]; 
    for (var i = 0; i < len; i++) 
    { 
     if (i in t) 
     { 
     var val = t[i]; // in case fun mutates this 
     if (fun.call(thisp, val, i, t)) 
      res.push(val); 
     } 
    } 

    return res; 
    }; 
} 

Desde: https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Array/filter

O dado que está utilizando jQuery, puede envolver su matriz en un objeto jQuery primera:

songs = $(songs).filter(function(){ 
    return this.album==album; 
}); 
+1

El argumento para la función de filtro es un índice. Para obtener el elemento real, simplemente puede usar 'this'. http://api.jquery.com/filter/ – Dennis

+2

¡Gracias! Esto funcionó perfectamente. –

+0

También podría hacer i, v en la función, donde v es la matriz yi es el elemento. –

0

¿Funciona el uso de la función attr()?

songs = songs.filter(function (index) { 
    return $(this).attr("album") == album; 
}); 
1

Utilice es5-shim, para que pueda usar filter/indexOf en IE8!

Facebook's reac.js usando eso también.

<!--[if lte IE 8]> 
    <script type="text/javascript" src="/react/js/html5shiv.min.js"></script> 
    <script type="text/javascript" src="/react/js/es5-shim.min.js"></script> 
    <script type="text/javascript" src="/react/js/es5-sham.min.js"></script> 
    <![endif]--> 

https://github.com/es-shims/es5-shim

Cuestiones relacionadas