首頁  >  文章  >  web前端  >  怎麼做vue-baidu-map進入頁面自動定位

怎麼做vue-baidu-map進入頁面自動定位

php中世界最好的语言
php中世界最好的语言原創
2018-06-01 17:25:461734瀏覽

這次給大家帶來怎樣做出vue-baidu-map進入頁面自動定位,vue-baidu-map進入頁面自動定位的注意事項有哪些,下面就是實戰案例,一起來看一下。

其實之前也被這問題困擾過,在網路上也查了一番,沒找到解決方法。直到今天,在GitHub 冒昧地向大佬提了一個 issue,才點醒了我。其實是因為太過急功近利了,沒有認真閱讀 vue-baidu-map 提供參考文檔,也有可能是看過然後忘記了!

首先要明確一點(文檔原話):由於百度地圖 JS API 只有 JSONP 一種載入方式,因此 BaiduMap 元件及其所有子元件的渲染只能是異步的。因此,請使用在元件的 ready 事件來執行地圖 API 載入完畢後才能執行的程式碼,不要試圖在 vue 自身的生命週期中呼叫 BMap 類,更不要在這些時機修改 model 層。

錯誤用法

 我試過,以上這個方法好像是可行,效果可以出來,但我們最好採用作者提供的正確方法!

正確用法

 推薦這個方法!那下面解決進入頁面自動定位的方法也是在這裡。

 下面是我的寫法,僅供參考,有不足請指出,我只是一個小白,哈哈!

Template:

<template>
  <baidu-map class="map" :center="center" :zoom="zoom" @ready="handler" @load="loadding" :scroll-wheel-zoom="true"
    :mapStyle="{styleJson: styleJson}">
    <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :showAddressBar="false" :autoLocation="true"
      :locationIcon="{url: require(&#39;../../svg/location.svg&#39;), size: {width: 18, height: 18}}" 
      @locationSuccess="getLoctionSuccess" @locationError="getLocationError">
    </bm-geolocation>
    <!-- 自定义定位图标覆盖物 -->
    <bm-marker :position="autoLocationPoint"
      :icon="{url: require(&#39;../../svg/location.svg&#39;), size: {width: 18, height: 18}}" v-if="initLocation">
    </bm-marker>
  </baidu-map>
</template>

JS實作:

<script>
  export default {
    data () {
      return {
        // 省略一部分
        autoLocationPoint: {lng: 0, lat: 0},
        initLocation: false,
      }
    },
    methods: {
      handler ({BMap, map}) {
        let _this = this;  // 设置一个临时变量指向vue实例,因为在百度地图回调里使用this,指向的不是vue实例;
        var geolocation = new BMap.Geolocation();
        geolocation.getCurrentPosition(function(r){
          console.log(r);
          _this.center = {lng: r.longitude, lat: r.latitude};   // 设置center属性值
          _this.autoLocationPoint = {lng: r.longitude, lat: r.latitude};   // 自定义覆盖物
          _this.initLocation = true; 
          console.log('center:', _this.center)  // 如果这里直接使用this是不行的
        },{enableHighAccuracy: true})

        // 下面注释是百度地图API官方实现方法,因为我使用自定义图标覆盖物,所以没有使用这种方法!
        // 如使用以下这种方法,那么我Template里所写的自定义定位图标代码是不需要的
        // 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());
        // }
        // },{enableHighAccuracy: true})
      }
    }
  }
</script>

我相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章!

推薦閱讀:

如何使用vue元件實作彈出框點選顯示隱藏

#如何使用vue彈窗訊息元件

#

以上是怎麼做vue-baidu-map進入頁面自動定位的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn