vue中使用百度地图api

最近研究了一下地图,这是是以百度地图为例(其他地图)用法一样,这里一步步来讲解。

前提是已经注册百度地图账号,申请开发者 详细操作,点击这里

首先要在打开百度地图API官网: 打开控制台,应用管理->我的应用。复制一个ak,注意pc应用,要选择浏览器端.

 打开vue项目在index.html中引入   密钥就是我的应用中的ak

<script type="text/javascript" src="https://api.map.baidu.com/api?v=1.0&&type=webgl&ak=您的密钥">
</script>

创建一个map.vue文件,来一步一步配置

<template>
     <div id="map" style="width:100%;height:100vh;position: relative;"></div>
</template>

<script>
export default {
  data(){
    return{
      lng:'120.096',
      lat:'30.2904',
      keyword:'',
      localSearch:null,
      markers: [
      {lng: 120.096, lat: 30.2904},
      {lng: 120.096, lat: 30.2902},
      {lng: 120.096, lat: 30.2903},
      {lng: 120.096, lat: 30.29041},
    ]
    }
  },
  methods:{
    search(){
      this.localSearch(this.keyword)
    }
  },
mounted() {
  // 获取当前的经纬度
navigator.geolocation.getCurrentPosition(posiaion => {
      console.log(posiaion.coords);
  })
let map = new window.BMapGL.Map("map");          // 创建地图实例 
let point = new window.BMapGL.Point(this.lng,this.lat);  // 创建点坐标 
let scaleCtrl = new window.BMapGL.ScaleControl()   //添加比例尺
map.addControl(scaleCtrl);
let zoomCtrl = new window.BMapGL.ZoomControl();  // 添加缩放控件
map.addControl(zoomCtrl);
let cityCtrl = new window.BMapGL.CityListControl();  // 添加城市列表控件
map.addControl(cityCtrl);
map.enableScrollWheelZoom(true);   //开启滚轮缩放
// 添加单个标注点
// let marker = new window.BMapGL.Marker(point); 
// map.addOverlay(marker);   //将单个标注点添加到地图中
// 添加多个标注点
let moreMarker=null
this.markers.map((item,index)=>{
   moreMarker=new window.BMapGL.Marker(new window.BMapGL.Point(this.markers[index].lng,this.markers[index].lat))
map.addOverlay(moreMarker);                     // 将多个标注点标注添加到地图中
})
// //添加带有高度的遮盖物
// let  marker3d = new window.BMapGL.Marker3D(point, 8000, {
//   size: 50,  //控制范围的大小
//   shape: 'BMAP_SHAPE_CIRCLE',  //遮盖物的形状
//   fillColor: '#454399',  //范围的颜色
//   fillOpacity: 0.6   //透明图
// });
// map.addOverlay(marker3d);
// 绑定事件
// map.addEventListener('click',(e)=>{
//   let geoc = new window.BMapGL.Geocoder(); //地址解析对象
//             //获取经纬度
//             //e.latlng.lng-经度
//             //e.latlng.lat-纬度
//             // 将获取到的经纬度转化为坐标
//   let pt = new window.BMapGL.Point(e.latlng.lng, e.latlng.lat);
//   geoc.getLocation(pt, (re)=>{
//     console.log(re);  //可以获取点击位置的详细信息
//   })
// })
map.centerAndZoom(point, 15);             // 初始化地图,设置中心点坐标和地图级别
}
}
</script>

这里有一些容易踩坑的地方

在官网中,使用的都是new BMap 在项目中使用时会报错   BMap未定义,

把new BMap改成new window.BMapGL即可

以上就是一些简单的配置,还在更新中,有问题随时私信即可,还在持续更新中(准备加上搜索功能)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值