中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue-baidu-map進入頁面自動定位的示例分析

發布時間:2021-08-02 14:56:03 來源:億速云 閱讀:164 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關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('../../svg/location.svg'), size: {width: 18, height: 18}}" 
      @locationSuccess="getLoctionSuccess" @locationError="getLocationError">
    </bm-geolocation>
    <!-- 自定義定位圖標覆蓋物 -->
    <bm-marker :position="autoLocationPoint"
      :icon="{url: require('../../svg/location.svg'), 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>

如果是直接復制代碼的朋友請注意,要有選擇的復制,因為我沒有把全部代碼貼出了,直接復制到你的項目是會出問題的!不過這代碼比較簡單,稍微就能看懂,哈哈!

關于“vue-baidu-map進入頁面自動定位的示例分析”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

郁南县| 奉新县| 扎兰屯市| 温宿县| 内乡县| 迁西县| 应城市| 亳州市| 婺源县| 台州市| 宜春市| 柏乡县| 保靖县| 罗源县| 永靖县| 绥中县| 辉县市| 邮箱| 仙游县| 浏阳市| 都兰县| 信丰县| 青川县| 德兴市| 丹东市| 罗江县| 景宁| 西青区| 娱乐| 依兰县| 甘孜| 湛江市| 汪清县| 临朐县| 伊川县| 偃师市| 上饶市| 香河县| 墨竹工卡县| 格尔木市| 枣庄市|