Como una continuación de mi mínimo/máximo en una matriz de objetos, me preguntaba acerca de las comparaciones de rendimiento de filtro frente a mapa.Problema con el mapa de filtro de Javascript
Así que hice una prueba de los valores en mi código ya que iba a ver los resultados en FireBug.
Este es el código:
var _vec = this.vec;
min_x = Math.min.apply(Math, _vec.filter(function(el){ return el["x"]; }));
min_y = Math.min.apply(Math, _vec.map(function(el){ return el["x"]; }));
La versión map
ped devuelve el resultado correcto. Sin embargo, la versión ed filter
devuelve NaN. Rompiéndolo, entrando y finalmente inspeccionando los resultados, parece que la función interna devuelve la propiedad x
de _vec
, pero la matriz real devuelta desde filter
es _vec
sin filtro.
Creo que el uso de filter
es correcto. ¿Alguien más puede ver mi problema?
Aquí es una prueba sencilla:
<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>S:GTC Map Test</title>
</head>
<body>
<script type="text/javascript">
function vector(x,y,z) { this.x = x; this.y =y; this.z=z; }
var vec = [];
vec.push(new vector(1,1,1));
vec.push(new vector(2,2,2));
vec.push(new vector(2,3,3));
var _vec = vec;
min_x = Math.min.apply(Math, _vec.filter(function(el){ return el["x"]; }));
min_y = Math.min.apply(Math, _vec.map(function(el){ return el["x"]; }));
document.write("<br>filter = " + min_x);
document.write("<br>map = " + min_y);
</script>
</body>
</html>
Ahh. Parece que no entendí cómo funciona el filtro functon. Tenía la impresión de que devolvía un objeto modificado a una matriz. –