Vue2項目中對百度地圖的封裝使用詳解
百度地圖的使用:
vue項目,有個 vue-baidu-map 可以用,但是好久不更新了。
React項目,百度官方出了個React版的,可以直接用,React-BMapGL。
除此以外,百度官方的都是 JavaScript API,這里以此來用vue封裝下,方便使用。
需求
- 組件按需引入。個人喜歡代碼干干凈凈,只要項目需要的功能就行了
- 簡單的封裝下,方便直接按官方文檔使用需要的功能,方便復(fù)用
- 基于Vue2 、JavaScript API v3.0
- 基于項目需求封裝,有些東西沒弄,需要的自己DIY吧
知識點
- Vue插槽 slot,方便在地圖上使用各種百度地圖功能
- Vue通知 emit、on。為了傳參,主要是獲取地圖map對象
- Vue組件封裝,加載地圖后,各種地圖功能,如:打點、劃線、彈窗等一系列的封裝使用
- 百度地圖自定義彈窗的實現(xiàn);彈窗調(diào)用vue內(nèi)部方法的實現(xiàn)
實現(xiàn)
components – bmap – index.vue
地圖單文件組件,主要代碼如下,具體參考代碼
<template> <div class="bmap-view"> <div id="bmapcontainer" :style="{ height: mapHeight }" /> <slot /> </div> </template> <script> import indexjs from './index.js' export default { ...indexjs } </script> <style lang='scss' scoped> </style>
components - bmap - bmap-jsapi-loader - index.js
百度地圖異步加載的處理文件,具體看代碼
components – map – index.js
地圖組件的業(yè)務(wù)代碼,可以配置地圖開放的屬性props和監(jiān)聽事件。
例如這里,開放了ak(申請的百度地圖key),styleId(百度地圖樣式id),zoom(縮放值),center(地圖加載默認(rèn)中心點),height(地圖默認(rèn)高度值)
主要代碼如下,具體參考代碼
import BMapLoader from './bmap-jsapi-loader' export default { name: 'BmapView', props: { ak: { type: String, default: 'ZMVYYKDUVYZIHl5ygAaKyBhs7Gkg24SX' }, styleId: { type: String, default: '41d153e7e9e7bcda9541996853046c93' }, zoom: { type: Number, default: 15 }, center: { type: [Array, String], default() { return [113.22682, 23.410167] } }, height: { type: Number | String, default: 520 } }, computed: { mapHeight() { return isNaN(this.height) ? this.height : `${this.height}px` } }, data() { return { map: '' } }, beforeDestroy() { this.map = null }, mounted() { }, created() { this.initMap() }, methods: { initMap() { BMapLoader.load({ key: this.ak, version: '3.0' }).then((BMap) => { this.map = new BMap.Map('bmapcontainer', { enableBizAuthLogo: false }) const point = new BMap.Point(this.center[0], this.center[1]) this.map.centerAndZoom(point, this.zoom) this.map.setMapStyleV2({ styleId: this.styleId }) this.$emit('bmap-ready', this.map) }).catch(e => { console.log(e) }) } }, watch: {} }
以上是使用百度地圖的基礎(chǔ)
調(diào)用方式
views - bmapTest - index.js
components: { BmapView: () => import ('@/components/bmap/index.vue') }
views - bmapTest - index.vue
<bmap-view />
效果圖
打點控件封裝
參考文檔 jsapi_reference_3_0
具體去看 bMarker.vue 文件了,去除百度地圖的默認(rèn)彈窗樣式,真的太惡心了。 這里主要值得參考的是自定義彈窗時,html里面通過vue的 runtimeCompiler: true
運行時編譯功能,可以調(diào)用vue里面的參數(shù)和方法,這里對于自定義是很方便的。
效果圖
代碼總覽
涉及的文件如下(具體參考代碼):
|-- public
|-- images // 注意,地圖需要到的圖片放這里
|-- src
|-- components
|-- bmap
|-- bmap-jsapi-loader
|-- index.js
|-- bMarker.vue // 打點、彈窗控件封裝
|-- index.vue // 地圖單文件組件,供界面調(diào)用
|-- index.js // 地圖初始化、配置相關(guān)
|-- views
|-- bmapTest // 演示實例所在
|-- index.vue
|-- index.scss
|-- index.js
代碼
按代碼總覽的目錄去代碼里找著看就行了。
總結(jié)
以上,只是簡單的封裝。百度地圖的api真的是不如高德地圖好用。以上的封裝已滿足本人項目需求,別的功能可以自己按需擴展了。
到此這篇關(guān)于Vue2項目中對百度地圖封裝使用的文章就介紹到這了,更多相關(guān)Vue2百度地圖封裝使用內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別
本文主要介紹了淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07