【发布时间】:2014-03-28 09:40:27
【问题描述】:
我的代码:
function addMarkerDraggable(group_id) {
// get current view center location
var current_view = map.getCenter();
var current_lat = current_view.lat();
var current_lng = current_view.lng();
var mp_id;
// ajax add marker to db.
$.ajax({
url: base_url+'myplaces/control/addplace/'+group_id,
type: 'POST',
data: csrf_name+'='+nocsrf_val+'&mp_latitude='+current_lat+'&mp_longitude='+current_lng,
dataType: 'json',
success: function(data) {
if (data.result === true) {
var mp_id = data.mp_id;
}
}
});
console.log(mp_id); // #pos.1
if (mp_id != 'undefined' && mp_id != '') {
var marker_icon = 'red.png';
var marker = new google.maps.Marker({
draggable: true,// ให้ลาก marker ได้ก็กำหนดเป็น true
position: current_view,
icon: iconBase + marker_icon,
map: map,
title: ''
});
google.maps.event.addListener(marker, 'dragend', function() {
update_position = marker.getPosition();
update_lat = update_position.lat();
update_lng = update_position.lng();
console.log(mp_id); // #pos.2
ajaxUpdateMarkerDraggedPosition(mp_id, update_lat, update_lng);
});
}
}// addMarkerDraggable
似乎我无法从 .ajax({}); 设置 var mp_id;并且无法从 #pos.1 和 #pos.2 的 mp_id 变量中获取值。
如何从 jquery ajax 内部设置 mp_id 并从谷歌地图关闭函数访问它?
【问题讨论】:
-
简单的答案,你不能这样做,因为ajax是异步的-如何解决它见上面的链接
标签: javascript jquery ajax closures