谷歌地图API - LatLng返回NaN

时间:2014-02-09 18:33:29

标签: javascript jquery google-maps

由于某些未知原因,我的latlng对象返回NaN。

HTML:

<td class="addresslatlng" style="display:none">(60.1932146, 24.9068178)</td>
<td class="addresslatlng" style="display:none">(60.1883387, 24.95304060000001)</td>
<td class="addresslatlng" style="display:none">(60.22956294570635, 24.877114473016377)</td>
and so on..

JS:

var geolocation = $(".addresslatlng").text();

var marker1 = $(".addresslatlng").each(function(){
    var markers = []; 
    var value = $(this).text();
    var strippedtemp = value.replace('(', '').replace(')','').replace(' ', '').replace(/\"/g, "");      
    var splittedtemp = strippedtemp.split(",");
    var marker = splittedtemp;
    markers.push(marker);           

    function setMarkers(map, locations) {
        var myLatLng1 = new google.maps.LatLng(parseFloat(markers[0]), parseFloat(markers[1]));
        var marker1 = new google.maps.Marker({
        position: myLatLng1,
        map: new google.maps.Map(document.getElementById('map-canvas2'))
    });


};
setMarkers();   
});

parsefloat(markers [0])工作正常,但由于某种原因,parsefloat(markers [1])将始终返回NaN。即使我将固定数字作为值,例如new google.maps.LatLng(60.1932146,60.1932146),myLatLng1也会始终将第二个值作为NaN返回;

不能为我的生活找出原因。有什么提示吗?

1 个答案:

答案 0 :(得分:1)

你必须使用

new google.maps.LatLng(parseFloat(markers[0][0]), parseFloat(markers[0][1]));

因为数组中的markers,其中一个元素是两个元素的数组。