点击我的.preview
按钮时,它会查看textarea
中的每个地址,然后绘制它。
我想在每次点击.preview
时删除标记,因为我看到它只是绘制了与之前标记相同点的另一个标记。
$('.preview').click(function(){
setAllMap(null);
var temp_addresses = document.getElementById("gps").value.split("\n");
for(var i=0;i<temp_addresses.length;i++){
addresses.push(temp_addresses[i]);
geocoder.geocode( { 'address': temp_addresses[i]}, function(response, status) {
geocode_results[i] = new Array();
geocode_results[i]['status'] = status;
var top_location = response[0];
var lat = Math.round(top_location.geometry.location.lat() * 1000000)/1000000;
var lng = Math.round(top_location.geometry.location.lng() * 1000000)/1000000;
geocode_results[i]['lat'] = lat;
geocode_results[i]['lng'] = lng;
geocode_results[i]['l_type'] = top_location.geometry.location_type;
marker = markers[i] = new google.maps.Marker({
icon: mapIcon,
position: new google.maps.LatLng(lat,lng),
map: map
});
});
}
});
这给了我一个ReferenceError: setAllMap is not defined
我试过了marker.setMap(null);
,但我回来了TypeError: marker.setMap is not a function
感谢帮助
编辑。
var marker = [];
var addresses = new Array();
var geocode_results = new Array();
function setAllMap(map) {
for (var i = 0; i < marker.length; i++) {
marker[i].setMap(map);
}
}
$('.preview').click(function(){
setAllMap(null);
var temp_addresses = document.getElementById("gps").value.split("\n");
for(var i=0;i<temp_addresses.length;i++){
addresses.push(temp_addresses[i]);
geocoder.geocode( { 'address': temp_addresses[i]}, function(response, status) {
geocode_results[i] = new Array();
geocode_results[i]['status'] = status;
var top_location = response[0];
var lat = Math.round(top_location.geometry.location.lat() * 1000000)/1000000;
var lng = Math.round(top_location.geometry.location.lng() * 1000000)/1000000;
geocode_results[i]['lat'] = lat;
geocode_results[i]['lng'] = lng;
geocode_results[i]['l_type'] = top_location.geometry.location_type;
marker = markers[i] = new google.maps.Marker({
icon: mapIcon,
position: new google.maps.LatLng(lat,lng),
map: map
});
});
}
});
答案 0 :(得分:0)
你需要创建一个setAllMap函数(它不是API的一部分)......如果markers数组在全局范围内,这应该可行。
function setAllMap(map) {
for (var i = 0; i < markers.length; i++) {
markers[i].setMap(map);
}
}
或者您可以将循环放在您调用函数的位置。