my code:
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
It seems that i cannot set var mp_id from .ajax({}); and cannot get value from mp_id variable from #pos.1 and #pos.2.
How to set mp_id from inside jquery ajax and access it from google map closure function?