js:
1 $.getJSON("./GetStationPlaceServlet",function(json){ 2 for(var i=0;i<json.length;i++){ 3 var obj1 = eval(json); 4 //獲取經緯度 5 fStationlon = parseFloat(obj1[i].Stationlon); 6 fStationlat = parseFloat(obj1[i].Stationlat); 7 var pt = new BMap.Point(fStationlon,fStationlat); 8 var myIcon = new BMap.Icon("photo/station.png",new BMap.Size(50,50),{ anchor: new BMap.Size(10, 10) }); 9 var marker = new BMap.Marker(pt,{icon:myIcon}); // 創建標注 10 map.addOverlay(marker); //將標注添加到地圖中 11 var strRes = parseFloat(obj1[i].StationId); 12 addClickHandler(strRes,marker);//左鍵單擊marker事件 13 RightClickHandler(strRes,marker);//右鍵單擊marker出現右鍵菜單事件 14 RightClick();//右鍵地圖出現右鍵菜單事件 15 } 16 }); 17 //右鍵單擊marker出現右鍵菜單事件 18 function RightClickHandler(stationId,marker){ 19 var removeMarker = function(e,ee,marker){//右鍵刪除站點 20 var json={ 21 "StationId":stationId, 22 }; 23 if (confirm("要刪除站點"+stationId+"嗎?")){ 24 if(true){ 25 $.getJSON("./DeleteStationServlet",{json:JSON.stringify(json)},function(json){ 26 if(json.result==true){ 27 alert("刪除站點"+stationId+"成功!"); 28 map.removeOverlay(marker); //將地圖中的標記刪除 29 } 30 }); 31 } 32 } 33 }; 34 var updateMarker = function(marker){//右鍵更新站名 35 if (confirm("要修改站點"+stationId+"的站名嗎?")){ 36 if(true){ 37 $(".AllUpdateMassage").show(); 38 $("#stationId").val(stationId); 39 } 40 } 41 }; 42 var markerMenu=new BMap.ContextMenu(); 43 markerMenu.addItem(new BMap.MenuItem('刪除站點',removeMarker.bind(marker))); 44 markerMenu.addItem(new BMap.MenuItem('修改站名',updateMarker.bind(marker))); 45 marker.addContextMenu(markerMenu);//給標記添加右鍵菜單 46 } 47 //鼠標左鍵單擊marker事件 48 function addClickHandler(stationId,marker){ 49 marker.addEventListener("click",function(e){ 50 var p = marker.getPosition(); //獲取marker的位置 51 var staId={ 52 "StationId":stationId, 53 }; 54 $.getJSON("./GetStationInfoServlet",{json:JSON.stringify(staId)},function(json){ 55 56 for(var i=0;i<json.length;i++){ 57 var obj1 = eval(json); 58 59 stationName = obj1[i].stationName; 60 61 var content = "站點編號:"+stationId+"<br/>"+ "站點名稱:"+stationName; 62 openInfo(content,e); 63 } 64 }); 65 }); 66 } 67 //左鍵單擊marker彈出窗口事件 68 function openInfo(content,e){ 69 var p = e.target; 70 var point = new BMap.Point(p.getPosition().lng, p.getPosition().lat); 71 var infoWindow = new BMap.InfoWindow(content,opts); // 創建信息窗口對象 72 map.openInfoWindow(infoWindow,point); //開啟信息窗口 73 } 74 //修改站點站名 75 function update(){ 76 var stationId=$("#stationId").val();//編號 77 var stationName=$(".AllUpdateMassage_name").val();//名字 78 79 var json={ 80 "StationId":stationId, 81 "StationName":stationName 82 }; 83 84 $.getJSON("./UpdateStationServlet",{json:JSON.stringify(json)},function(json){ 85 86 if(json.result==true){ 87 alert("站點"+stationId+"站名修改成功!"); 88 $(".AllUpdateMassage").hide(); 89 } 90 else{ 91 alert("失敗!"); 92 } 93 }); 94 95 }
效果圖:
地圖上和數據庫中都已刪除此點信息:
我在實現這個時,發現有人只能在一個marker上添加右鍵菜單。我這個不存在這個問題。原理好像是關於閉包啥的,我也是新手不是很清楚,望懂得人不惜指教。