vue-baidu-map 進(jìn)入頁面自動定位的解決方案(推薦)
寫在前面:我只是一個前端小白,文章中的提到可能會有不足之處,僅提供一個參考。若有不完善的地方,歡迎各位大佬指出!,希望對你有幫助!
好了,入正題。其實之前也被這問題困擾過,在網(wǎng)上也查了一番,沒找到解決方法。直到今天,在GitHub 冒昧地向大佬提了一個 issue,才點醒了我。其實是因為太過急功近利了,沒有認(rèn)真閱讀 vue-baidu-map 提供參考文檔,也有可能是看過然后忘記了!
首先要明確一點(文檔原話):由于百度地圖 JS API 只有 JSONP 一種加載方式,因此 BaiduMap 組件及其所有子組件的渲染只能是異步的。因此,請使用在組件的 ready 事件來執(zhí)行地圖 API 加載完畢后才能執(zhí)行的代碼,不要試圖在 vue 自身的生命周期中調(diào)用 BMap 類,更不要在這些時機(jī)修改 model 層。
錯誤用法
我試過,以上這種方法好像是可行,效果可以出來,但我們最好采用作者提供的正確方法!
正確用法
推薦這種方法!那下面解決進(jìn)入頁面自動定位的方法也是在這里。
下面是我的寫法,僅供參考,有不足請指出,我只是一個小白,哈哈!
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實現(xiàn):
<script>
export default {
data () {
return {
// 省略一部分
autoLocationPoint: {lng: 0, lat: 0},
initLocation: false,
}
},
methods: {
handler ({BMap, map}) {
let _this = this; // 設(shè)置一個臨時變量指向vue實例,因為在百度地圖回調(diào)里使用this,指向的不是vue實例;
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官方實現(xiàn)方法,因為我使用自定義圖標(biāo)覆蓋物,所以沒有使用這種方法!
// 如使用以下這種方法,那么我Template里所寫的自定義定位圖標(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ù)制代碼的朋友請注意,要有選擇的復(fù)制,因為我沒有把全部代碼貼出了,直接復(fù)制到你的項目是會出問題的!不過這代碼比較簡單,稍微就能看懂,哈哈!
以上所述是小編給大家介紹的vue-baidu-map 進(jìn)入頁面自動定位的解決方案,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
vue router 跳轉(zhuǎn)時打開新頁面的示例方法
這篇文章主要介紹了vue router 跳轉(zhuǎn)時打開新頁面的示例方法,本文通過示例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-07
vue.js element-ui tree樹形控件改iview的方法
這篇文章主要介紹了vue.js element-ui tree樹形控件改iview的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03
淺談Vue.js應(yīng)用的四種AJAX請求數(shù)據(jù)模式
本篇文章主要介紹了淺談Vue.js應(yīng)用的四種AJAX請求數(shù)據(jù)模式,本文將詳細(xì)介紹在Vue應(yīng)用程序中實現(xiàn)AJAX的四個方法,有興趣的可以了解一下2017-08-08
使用Vue3和Pinia實現(xiàn)網(wǎng)頁刷新功能
在現(xiàn)代 Web 開發(fā)中,保持用戶界面的動態(tài)性和響應(yīng)性至關(guān)重要,當(dāng)用戶觸發(fā)某些操作時,例如點擊按鈕或者完成表單提交,我們往往需要刷新頁面的一部分來展示最新的數(shù)據(jù),本文將介紹如何使用 Vue 3 和 Pinia 來實現(xiàn)這一功能,需要的朋友可以參考下2024-08-08
Nuxt.js nuxt-link與router-link的區(qū)別說明
這篇文章主要介紹了Nuxt.js nuxt-link與router-link的區(qū)別說明,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11
vue mounted()函數(shù)中無法定義初始化樣式的原因分析
這篇文章主要介紹了vue mounted()函數(shù)中無法定義初始化樣式的原因分析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03

