vue 百度地图多标注展示和点击标注进行的提示

index.html中加入script

<script type="text/javascript" src="http://api.map.baidu.com/api?v=3.0&ak=2GRZTukOKUxe25P86mqjHuR1mTahwueb" ></script>
新建map.vue

<template>
  <div id="allmap"
       class="Map" />
</template>

<script>
/* eslint-disable*/


export default {
  name: 'Mapbox',
  data() {
    return {
    }
  },
  mounted: function () {
    this.$nextTick(() => {
      var map = new BMap.Map("allmap");   //初始化map, 绑定id=allmap
      var point = new BMap.Point(121.48789949, 31.24916171);   // 初始化point, 给定一个默认x,y值
      map.centerAndZoom(point, 10);        // 将point点放入map中,展示在页面中心展示,10=缩放程度
      map.enableScrollWheelZoom();         // 开启滚动鼠标滑轮

      // 如有多个point去展示,可根据后端接口传入为主
      let data = [
        { x: 116.297047, y: 39.979542, name: '张三' },
        { x: 116.321768, y: 39.88748, name: '李四' },
        { x: 116.494243, y: 39.756539, name: '王五' }
      ]

      data.forEach((e, i) => {
        // 创建point, 将x,y值传入
        let pointNumber = new BMap.Point(e.x, e.y)

        // 创建信息窗口对象  
        let infoWindow = new BMap.InfoWindow("World", {
          width: 150,     // 信息窗口宽度    
          height: 100,     // 信息窗口高度    
          title: "Hello" + i  // 信息窗口标题   
        });
        // 将data中的name加入地图中
        var label = new BMap.Label(e.name, {
          offset: new BMap.Size(25, 5)
        });
        markerFun(pointNumber, infoWindow, label)
      })

      function markerFun(points, infoWindows, label) {
        let markers = new BMap.Marker(points);
        map.addOverlay(markers);  // 将标注添加到地图中
        markers.setLabel(label);  // 将data中的name添加到地图中
        // 标注的点击事件
        markers.addEventListener("click", function (event) {
          map.openInfoWindow(infoWindows, points);//参数:窗口、点  根据点击的点出现对应的窗口
        });
      }

      // 获取当前地理位置
      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());
        }
      });

    })
  },
  methods: {

  }
}
</script>

<style>
.Map {
  height: calc(100vh - 126px);
  width: 100%;
}
</style>

  

posted @ 2019-08-06 17:08  小短腿奔跑吧  阅读(6785)  评论(0编辑  收藏  举报