2011-05-03 20 views
6

Quiero almacenar una matriz de latitudes/longitudes. Tengo estas entradas en mi página:Crear una matriz de objetos en jQuery

<input type="hidden" class="latitude" value="-12.3456" /> 
<input type="hidden" class="longitude" value="12.3456" /> 
<input type="hidden" class="latitude" value="98.7654" /> 
<input type="hidden" class="longitude" value="-98.7654" /> 

Y los estoy poniendo en matrices de este modo:

var latitudes = $('.latitude').map(function() { return this.value; }).get(); 
var longitudes = $('.longitude').map(function() { return this.value; }).get(); 

Pero estoy pensando que sería mejor para almacenarlos en una sola matriz como objetos, por lo que puedo decir:

$.each(array, function (i, obj) { 
    alert(obj.Latitude); 
    alert(obj.Longitude); 
}); 

¿Cómo puedo modificar esto para crear una matriz de objetos?

Respuesta

6

me gustaría utilizar jQuery.map():

$.map(latitudes, function(lat, i) { 
    return {latitude:lat, longitude:longitudes[i]}; 
}); 
+0

bueno saber jQuery tiene una función de mapa! –

0

Esta es una manera:

http://jsfiddle.net/95cga/

var longs=$(".longitude"); 
var lats=$(".latitude"); 

var objs=[]; 

for(var i=0;i<Math.min(longs.length,lats.length);i++){ 
    var obj={ 
     "Latitude" : longs.eq(i).val(), 
     "Longitude" : lats.eq(i).val() 
    } 

    objs.push(obj); 
} 

no me gusta asumir las cosas están siempre en pares, aunque deberían ser. Es por eso que Math.min está ahí.

2
var coords = []; 
$.each(latitudes, function(index, value) { 
    coords.push({'Latitude': value, 'Longitude': longitudes[index]}); 
}); 
Cuestiones relacionadas