亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue-baidu-map 進(jìn)入頁(yè)面自動(dòng)定位的解決方案(推薦)

 更新時(shí)間:2018年04月28日 08:42:36   作者:越前君  
這篇文章主要介紹了vue-baidu-map 進(jìn)入頁(yè)面自動(dòng)定位的解決方案,需要的朋友可以參考下

寫(xiě)在前面:我只是一個(gè)前端小白,文章中的提到可能會(huì)有不足之處,僅提供一個(gè)參考。若有不完善的地方,歡迎各位大佬指出!,希望對(duì)你有幫助!

好了,入正題。其實(shí)之前也被這問(wèn)題困擾過(guò),在網(wǎng)上也查了一番,沒(méi)找到解決方法。直到今天,在GitHub 冒昧地向大佬提了一個(gè) issue,才點(diǎn)醒了我。其實(shí)是因?yàn)樘^(guò)急功近利了,沒(méi)有認(rèn)真閱讀 vue-baidu-map 提供參考文檔,也有可能是看過(guò)然后忘記了!

首先要明確一點(diǎn)(文檔原話(huà)):由于百度地圖 JS API 只有 JSONP 一種加載方式,因此 BaiduMap 組件及其所有子組件的渲染只能是異步的。因此,請(qǐng)使用在組件的 ready 事件來(lái)執(zhí)行地圖 API 加載完畢后才能執(zhí)行的代碼,不要試圖在 vue 自身的生命周期中調(diào)用 BMap 類(lèi),更不要在這些時(shí)機(jī)修改 model 層。

錯(cuò)誤用法

 我試過(guò),以上這種方法好像是可行,效果可以出來(lái),但我們最好采用作者提供的正確方法!

正確用法

 推薦這種方法!那下面解決進(jìn)入頁(yè)面自動(dòng)定位的方法也是在這里。

 下面是我的寫(xiě)法,僅供參考,有不足請(qǐng)指出,我只是一個(gè)小白,哈哈!

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>
    <!-- 自定義定位圖標(biāo)覆蓋物 -->
    <bm-marker :position="autoLocationPoint"
      :icon="{url: require('../../svg/location.svg'), size: {width: 18, height: 18}}" v-if="initLocation">
    </bm-marker>
  </baidu-map>
</template>

JS實(shí)現(xiàn):

<script>
  export default {
    data () {
      return {
        // 省略一部分
        autoLocationPoint: {lng: 0, lat: 0},
        initLocation: false,
      }
    },
    methods: {
      handler ({BMap, map}) {
        let _this = this;  // 設(shè)置一個(gè)臨時(shí)變量指向vue實(shí)例,因?yàn)樵诎俣鹊貓D回調(diào)里使用this,指向的不是vue實(shí)例;
        var geolocation = new BMap.Geolocation();
        geolocation.getCurrentPosition(function(r){
          console.log(r);
          _this.center = {lng: r.longitude, lat: r.latitude};   // 設(shè)置center屬性值
          _this.autoLocationPoint = {lng: r.longitude, lat: r.latitude};   // 自定義覆蓋物
          _this.initLocation = true; 
          console.log('center:', _this.center)  // 如果這里直接使用this是不行的
        },{enableHighAccuracy: true})

        // 下面注釋是百度地圖API官方實(shí)現(xiàn)方法,因?yàn)槲沂褂米远x圖標(biāo)覆蓋物,所以沒(méi)有使用這種方法!
        // 如使用以下這種方法,那么我Template里所寫(xiě)的自定義定位圖標(biāo)代碼是不需要的
        // 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>

如果是直接復(fù)制代碼的朋友請(qǐng)注意,要有選擇的復(fù)制,因?yàn)槲覜](méi)有把全部代碼貼出了,直接復(fù)制到你的項(xiàng)目是會(huì)出問(wèn)題的!不過(guò)這代碼比較簡(jiǎn)單,稍微就能看懂,哈哈!

以上所述是小編給大家介紹的vue-baidu-map 進(jìn)入頁(yè)面自動(dòng)定位的解決方案,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue之如何實(shí)現(xiàn)打印功能

    vue之如何實(shí)現(xiàn)打印功能

    這篇文章主要介紹了vue之如何實(shí)現(xiàn)打印功能問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • vue router 跳轉(zhuǎn)時(shí)打開(kāi)新頁(yè)面的示例方法

    vue router 跳轉(zhuǎn)時(shí)打開(kāi)新頁(yè)面的示例方法

    這篇文章主要介紹了vue router 跳轉(zhuǎn)時(shí)打開(kāi)新頁(yè)面的示例方法,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-07-07
  • Vue.js計(jì)算屬性computed與watch(5)

    Vue.js計(jì)算屬性computed與watch(5)

    這篇文章主要為大家詳細(xì)介紹了Vue.js計(jì)算屬性computed與watch,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • vue.js element-ui tree樹(shù)形控件改iview的方法

    vue.js element-ui tree樹(shù)形控件改iview的方法

    這篇文章主要介紹了vue.js element-ui tree樹(shù)形控件改iview的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • vue3?錨點(diǎn)定位的多種實(shí)現(xiàn)方式

    vue3?錨點(diǎn)定位的多種實(shí)現(xiàn)方式

    這篇文章主要介紹了vue3?多種方法的錨點(diǎn)定位,使用?Vue?Router?導(dǎo)航守衛(wèi)可以簡(jiǎn)化導(dǎo)航邏輯、統(tǒng)一管理導(dǎo)航邏輯和進(jìn)行權(quán)限控制,但需要學(xué)習(xí)和理解相關(guān)概念,并且需要手動(dòng)編寫(xiě)和管理導(dǎo)航守衛(wèi)的邏輯,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-07-07
  • 淺談Vue.js應(yīng)用的四種AJAX請(qǐng)求數(shù)據(jù)模式

    淺談Vue.js應(yīng)用的四種AJAX請(qǐng)求數(shù)據(jù)模式

    本篇文章主要介紹了淺談Vue.js應(yīng)用的四種AJAX請(qǐng)求數(shù)據(jù)模式,本文將詳細(xì)介紹在Vue應(yīng)用程序中實(shí)現(xiàn)AJAX的四個(gè)方法,有興趣的可以了解一下
    2017-08-08
  • 使用Vue3和Pinia實(shí)現(xiàn)網(wǎng)頁(yè)刷新功能

    使用Vue3和Pinia實(shí)現(xiàn)網(wǎng)頁(yè)刷新功能

    在現(xiàn)代 Web 開(kāi)發(fā)中,保持用戶(hù)界面的動(dòng)態(tài)性和響應(yīng)性至關(guān)重要,當(dāng)用戶(hù)觸發(fā)某些操作時(shí),例如點(diǎn)擊按鈕或者完成表單提交,我們往往需要刷新頁(yè)面的一部分來(lái)展示最新的數(shù)據(jù),本文將介紹如何使用 Vue 3 和 Pinia 來(lái)實(shí)現(xiàn)這一功能,需要的朋友可以參考下
    2024-08-08
  • Vue實(shí)現(xiàn)底部側(cè)邊工具欄的實(shí)例代碼

    Vue實(shí)現(xiàn)底部側(cè)邊工具欄的實(shí)例代碼

    這篇文章主要介紹了Vue實(shí)現(xiàn)底部側(cè)邊工具欄的實(shí)例代碼,文中通過(guò)分享一段代碼介紹vue 側(cè)邊導(dǎo)航欄遞歸顯示功能,需要的朋友可以參考下
    2018-09-09
  • Nuxt.js nuxt-link與router-link的區(qū)別說(shuō)明

    Nuxt.js nuxt-link與router-link的區(qū)別說(shuō)明

    這篇文章主要介紹了Nuxt.js nuxt-link與router-link的區(qū)別說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-11-11
  • vue mounted()函數(shù)中無(wú)法定義初始化樣式的原因分析

    vue mounted()函數(shù)中無(wú)法定義初始化樣式的原因分析

    這篇文章主要介紹了vue mounted()函數(shù)中無(wú)法定義初始化樣式的原因分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03

最新評(píng)論