前言:
前端時間剛好使用了百度地圖的js api定位獲取使用者當前經緯度並獲取當前詳細位置的功能,為了方便下次找起來方便一些自己在這裡記錄一下,希望也能夠幫助到有需要的童鞋們!
解決方案:
一、引入JavaScript API v2.0 SDK
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=您的金鑰"></script>
二、在頁面中定義一個以ID為allmap的DIV標籤:
<div id="allmap"></div>
避免頁面中出現:
Uncaught TypeError: Cannot read property 'gc' of undefined
三、通過SDK 輔助定位獲取座標,然後在獲取當前使用者詳細地址
<script type="text/javascript"> var map = new BMap.Map("allmap");//建立Map例項,注意頁面中一定要有個id為allmp的div var point = new BMap.Point(116.331398,39.897445);//建立定座標 map.centerAndZoom(point,12);//// 初始化地圖,設定中心點座標和地圖級別 var geolocation = new BMap.Geolocation(); var gc = new BMap.Geocoder();//建立地理編碼器 // 開啟SDK輔助定位 geolocation.enableSDKLocation(); geolocation.getCurrentPosition(function(r){ if(this.getStatus() == BMAP_STATUS_SUCCESS){ var mk = new BMap.Marker(r.point); map.addOverlay(mk); map.panTo(r.point); alert('您的位置:' + r.point.lng + ',' + r.point.lat); var pt = r.point; map.panTo(pt);//移動地圖中心點 //alert(r.point.lng);//X軸 //alert(r.point.lat);//Y軸 gc.getLocation(pt, function(rs){ var addComp = rs.addressComponents; //alert(addComp.city); alert(addComp.province + addComp.city + addComp.district + addComp.street + addComp.streetNumber); }); } else { alert('failed'+this.getStatus()); } }); </script>
四、通過瀏覽器定位獲取當前經緯度:
<script type="text/javascript"> var map = new BMap.Map("allmap"); var point = new BMap.Point(116.331398,39.897445); map.centerAndZoom(point,12); var geolocation = new BMap.Geolocation(); geolocation.getCurrentPosition(function(r){ if(this.getStatus() == BMAP_STATUS_SUCCESS){ var mk = new BMap.Marker(r.point); map.addOverlay(mk); map.panTo(r.point); alert('您的位置:'+r.point.lng+','+r.point.lat); } else { alert('failed'+this.getStatus()); } }); </script>
五、ip定位獲取當前所在城市
<script type="text/javasript"> var map = new BMap.Map("allmap"); var point = new BMap.Point(116.331398,39.897445); map.centerAndZoom(point,12); function myFun(result){ var cityName = result.name; map.setCenter(cityName); alert("當前定位城市:"+cityName); } var myCity = new BMap.LocalCity(); myCity.get(myFun); </script>