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

Vue2項目中對百度地圖的封裝使用詳解

 更新時間:2022年06月16日 11:10:24   作者:liyoro  
近期項目需求相關(guān)地圖限定使用百度地圖,功能比較簡單,下面這篇文章主要給大家介紹了關(guān)于Vue2項目中對百度地圖的封裝使用的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

百度地圖的使用:

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)文章

  • Vue中UI組件庫之Vuex與虛擬服務(wù)器初識

    Vue中UI組件庫之Vuex與虛擬服務(wù)器初識

    這篇文章主要介紹了Vue中UI組件庫之Vuex與虛擬服務(wù)器初識,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-05-05
  • vue3中vue-meta的使用方法解析

    vue3中vue-meta的使用方法解析

    這篇文章主要介紹了vue3中vue-meta的使用方法,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • vue3給動態(tài)渲染的組件添加ref的解決方案

    vue3給動態(tài)渲染的組件添加ref的解決方案

    ref和reactive一樣,也是用來實現(xiàn)響應(yīng)式數(shù)據(jù)的方法,下面這篇文章主要給大家介紹了關(guān)于vue3給動態(tài)渲染的組件添加ref的解決方案,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • 基于vue實現(xiàn)swipe分頁組件實例

    基于vue實現(xiàn)swipe分頁組件實例

    本篇文章主要介紹了基于vue實現(xiàn)swipe分頁組件實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • Vue js如何用split切分并去掉空值和item的空格

    Vue js如何用split切分并去掉空值和item的空格

    這篇文章主要介紹了Vue js如何用split切分并去掉空值和item的空格,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Vue實現(xiàn)省市區(qū)三級聯(lián)動

    Vue實現(xiàn)省市區(qū)三級聯(lián)動

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)省市區(qū)三級聯(lián)動,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • Vue實現(xiàn)6位數(shù)密碼效果

    Vue實現(xiàn)6位數(shù)密碼效果

    這篇文章主要為大家詳細介紹了Vue實現(xiàn)6位數(shù)密碼,優(yōu)化iOS WebView卡頓,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08
  • 淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別

    淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別

    本文主要介紹了淺談vue3中ref、toRef、toRefs?和?reactive的區(qū)別,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • 解決vuex刷新狀態(tài)初始化的方法實現(xiàn)

    解決vuex刷新狀態(tài)初始化的方法實現(xiàn)

    這篇文章主要介紹了解決vuex刷新狀態(tài)初始化的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 詳解vue實現(xiàn)坐標(biāo)拾取器功能示例

    詳解vue實現(xiàn)坐標(biāo)拾取器功能示例

    這篇文章主要介紹了詳解vue實現(xiàn)坐標(biāo)拾取器功能示例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11

最新評論