欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue2項(xiàng)目中對(duì)百度地圖的封裝使用詳解

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

百度地圖的使用:

vue項(xiàng)目,有個(gè) vue-baidu-map 可以用,但是好久不更新了。

React項(xiàng)目,百度官方出了個(gè)React版的,可以直接用,React-BMapGL。

除此以外,百度官方的都是 JavaScript API,這里以此來(lái)用vue封裝下,方便使用。

需求

  • 組件按需引入。個(gè)人喜歡代碼干干凈凈,只要項(xiàng)目需要的功能就行了
  • 簡(jiǎn)單的封裝下,方便直接按官方文檔使用需要的功能,方便復(fù)用
  • 基于Vue2 、JavaScript API v3.0
  • 基于項(xiàng)目需求封裝,有些東西沒(méi)弄,需要的自己DIY吧

知識(shí)點(diǎn)

  • Vue插槽 slot,方便在地圖上使用各種百度地圖功能
  • Vue通知 emit、on。為了傳參,主要是獲取地圖map對(duì)象
  • Vue組件封裝,加載地圖后,各種地圖功能,如:打點(diǎn)、劃線、彈窗等一系列的封裝使用
  • 百度地圖自定義彈窗的實(shí)現(xiàn);彈窗調(diào)用vue內(nèi)部方法的實(shí)現(xiàn)

實(shí)現(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ù)代碼,可以配置地圖開(kāi)放的屬性props和監(jiān)聽(tīng)事件。

例如這里,開(kāi)放了ak(申請(qǐng)的百度地圖key),styleId(百度地圖樣式id),zoom(縮放值),center(地圖加載默認(rèn)中心點(diǎ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 />

效果圖

打點(diǎn)控件封裝

參考文檔 jsapi_reference_3_0

具體去看 bMarker.vue 文件了,去除百度地圖的默認(rèn)彈窗樣式,真的太惡心了。 這里主要值得參考的是自定義彈窗時(shí),html里面通過(guò)vue的 runtimeCompiler: true運(yùn)行時(shí)編譯功能,可以調(diào)用vue里面的參數(shù)和方法,這里對(duì)于自定義是很方便的。

效果圖

代碼總覽

涉及的文件如下(具體參考代碼):

|-- public
    |-- images  // 注意,地圖需要到的圖片放這里
|-- src
    |-- components
        |-- bmap
            |-- bmap-jsapi-loader
                |-- index.js
            |-- bMarker.vue    // 打點(diǎn)、彈窗控件封裝
            |-- index.vue    // 地圖單文件組件,供界面調(diào)用
            |-- index.js    // 地圖初始化、配置相關(guān)
    |-- views
        |-- bmapTest    // 演示實(shí)例所在
            |-- index.vue
            |-- index.scss
            |-- index.js

代碼

按代碼總覽的目錄去代碼里找著看就行了。

總結(jié)

以上,只是簡(jiǎn)單的封裝。百度地圖的api真的是不如高德地圖好用。以上的封裝已滿足本人項(xiàng)目需求,別的功能可以自己按需擴(kuò)展了。

到此這篇關(guān)于Vue2項(xiàng)目中對(duì)百度地圖封裝使用的文章就介紹到這了,更多相關(guān)Vue2百度地圖封裝使用內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

    Vue實(shí)現(xiàn)省市區(qū)三級(jí)聯(lián)動(dòng)

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

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

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

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

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

    解決vuex刷新?tīng)顟B(tài)初始化的方法實(shí)現(xiàn)

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

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

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

最新評(píng)論