百度地图位置的获取展示
引入api文档以及js文件
<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=lxmItF5qknlkxlQ4sk56jg2Gvm2NU9Eiu1"></script>
普通使用
根据后台获取到的经纬度进行地图的展示
// 百度地图API功能
var map = new BMap.Map("allmap"); //allmap为页面中 id 为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);
console.log(r.address.city)
// alert('您的位置:'+r.point.lng+','+r.point.lat);
}
else {
alert('failed'+this.getStatus());
}
},{enableHighAccuracy: true})
//关于状态码
//BMAP_STATUS_SUCCESS 检索成功。对应数值“0”。
//BMAP_STATUS_CITY_LIST 城市列表。对应数值“1”。
//BMAP_STATUS_UNKNOWN_LOCATION 位置结果未知。对应数值“2”。
//BMAP_STATUS_UNKNOWN_ROUTE 导航结果未知。对应数值“3”。
//BMAP_STATUS_INVALID_KEY 非法密钥。对应数值“4”。
//BMAP_STATUS_INVALID_REQUEST 非法请求。对应数值“5”。
//BMAP_STATUS_PERMISSION_DENIED 没有权限。对应数值“6”。(自 1.1 新增)
//BMAP_STATUS_SERVICE_UNAVAILABLE 服务不可用。对应数值“7”。(自 1.1 新增)
//BMAP_STATUS_TIMEOUT 超时。对应数值“8”。(自 1.1 新增)
在vue中使用
1、在index.html 页面中引入百度地图的js文件
2、在config文件夹下的webpack.base.conf.js中,在module.export里添加拓展组件
externals: {
'BMap': 'BMap'
},
3、在要使用百度地图的地方引入BMap
import BMap from 'BMap'
4、在mounted钩子函数中初始化地图
初始化代码与上面类似