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

vue3.0引入百度地圖并標記點的實現(xiàn)代碼

 更新時間:2022年08月15日 10:15:27   作者:HHUFU..  
這篇文章主要介紹了vue3.0引入百度地圖并標記點,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

首先新建一個js,主要用來引入百度地圖的js,代碼如下:

export function baiduMap() {
    return new Promise(function(resolve, reject) {
        window.baiduMap = function() {
            resolve()
        }

        var script2 = document.createElement('script')
        script2.type = 'text/javascript'
        script2.src = `http://api.map.baidu.com/library/SearchInfoWindow/1.5/src/SearchInfoWindow_min.js`

        var link = document.createElement('link')
        link.rel = 'stylesheet'
        link.href = `http://api.map.baidu.com/library/SearchInfoWindow/1.5/src/SearchInfoWindow_min.css`

        document.head.appendChild(link)
        document.head.appendChild(script2)

        var script = document.createElement('script')
        script.type = 'text/javascript'
        script.src = `http://api.map.baidu.com/api?v=3.0&ak=你的ak&callback=baiduMap`
        script.onerror = reject
        document.head.appendChild(script)
    })
}

獲取生成密匙: ak密匙(百度地圖)

其次,創(chuàng)建baidu-map.vue,代碼如下:

<template>
  <el-dialog title="門店地圖分布" v-model="open" width="70%"  draggable>
    <div id="map" :style="{height:mapHeight}">
      <div id="allmap" ref="allmap" ></div>
    </div>
  </el-dialog>

</template>
<script setup name="BaiduMap">
import {baiduMap} from '@/api/post/baiduMap'
import {getLineShopMap} from '@/api/post/line'
import {nextTick} from "vue";

const mapHeight = ref('70vh')
const open = ref(false)
const allmap = ref(null)

function map(id) {
  open.value = true
  getLineShopMap(id).then(res => {
    var markerArr = []
    var data = res.data
    for (var i = 0; i < data.length; i++) {
      var point = data[i].lng + "," + data[i].lat;
      var shop = '{ title: "' + data[i].shopname + '",areaname: "' + data[i].name + '", point: "' + point + '", receiver: "' + data[i].receiver + '", mobile: "' + data[i].mobile + '" }';
      var shopobj = eval('(' + shop + ')');
      markerArr.push(shopobj);
    }
    nextTick(res => {
      baiduMap().then(thatMap => {
        // 創(chuàng)建地圖實例
        var map = new BMap.Map("map");
        var point = new BMap.Point(113.312213, 23.147267); //地圖中心點,廣州市
        map.centerAndZoom(point, 13); // 初始化地圖,設(shè)置中心點坐標和地圖級別。
        map.enableScrollWheelZoom(true); //啟用滾輪放大縮小
        //地圖、衛(wèi)星、混合模式切換
        map.addControl(new BMap.MapTypeControl({mapTypes: [BMAP_NORMAL_MAP, BMAP_SATELLITE_MAP, BMAP_HYBRID_MAP]}));
        //向地圖中添加縮放控件
        var ctrlNav = new window.BMap.NavigationControl({
          anchor: BMAP_ANCHOR_TOP_LEFT,
          type: BMAP_NAVIGATION_CONTROL_LARGE
        });
        map.addControl(ctrlNav);
        //向地圖中添加縮略圖控件
        var ctrlOve = new window.BMap.OverviewMapControl({
          anchor: BMAP_ANCHOR_BOTTOM_RIGHT,
          isOpen: 1
        });
        map.addControl(ctrlOve);
        //向地圖中添加比例尺控件
        var ctrlSca = new window.BMap.ScaleControl({
          anchor: BMAP_ANCHOR_BOTTOM_LEFT
        });
        map.addControl(ctrlSca);

        var point = new Array(); //存放標注點經(jīng)緯信息的數(shù)組
        var marker = new Array(); //存放標注點對象的數(shù)組
        var info = new Array(); //存放提示信息窗口對象的數(shù)組
        var searchInfoWindow = new Array();//存放檢索信息窗口對象的數(shù)組

        for (var i = 0; i < markerArr.length; i++) {
          var p0 = markerArr[i].point.split(",")[0]; //
          var p1 = markerArr[i].point.split(",")[1]; //按照原數(shù)組的point格式將地圖點坐標的經(jīng)緯度分別提出來
          point[i] = new window.BMap.Point(p0, p1); //循環(huán)生成新的地圖點
          marker[i] = new window.BMap.Marker(point[i]); //按照地圖點坐標生成標記
          map.addOverlay(marker[i]);
          marker[i].setAnimation(BMAP_ANIMATION_BOUNCE); //跳動的動畫
          //顯示marker的title,marker多的話可以注釋掉
          var label = new window.BMap.Label(markerArr[i].title, {offset: new window.BMap.Size(20, -10)});
          marker[i].setLabel(label);
          // 創(chuàng)建信息窗口對象  receiver: "'+data[i].receiver+'", mobile:
          info[i] = "<p style='font-size:14px;line-height:20px'>" + "</br>門店名稱:" + markerArr[i].title + "</br>所在區(qū)域:" + markerArr[i].areaname + "</br>接收人:" + markerArr[i].receiver + "</br> 門店電話:" + markerArr[i].mobile + "</br></p>";
          //創(chuàng)建百度樣式檢索信息窗口對象
          searchInfoWindow[i] = new BMapLib.SearchInfoWindow(map, info[i], {
            title: markerArr[i].title,      //標題
            width: 290,             //寬度
            // height : 40,              //高度
            panel: "panel",         //檢索結(jié)果面板
            enableAutoPan: true,     //自動平移
            searchTypes: [
              BMAPLIB_TAB_SEARCH,   //周邊檢索
              //    BMAPLIB_TAB_TO_HERE,  //到這里去
              //   BMAPLIB_TAB_FROM_HERE //從這里出發(fā)
            ]
          });

          //添加點擊事件
          marker[i].addEventListener("click",
              (function (k) {
                // js 閉包
                return function () {
                  //將被點擊marker置為中心
                  // map.centerAndZoom(point[k], 13);
                  // console.log(searchInfoWindow[k])
                  //在marker上打開檢索信息窗口
                  searchInfoWindow[k].open(marker[k]);
                }
              })(i)
          );
        }
      });
    })
  })
}

defineExpose({
  map
})

</script>
<style>
#allmap {
  height: 100%;
  overflow: hidden;
}
</style>


最后,在你需要用到的界面引用

引用界面的script的代碼

import BaiduMap from "./baidu-map";
const mapRef = ref(null);

/**
 * 查看地圖
 * @param selection
 */
function openMap() {
  mapRef.value.map(form.value.id)
}

最終效果

參考:博客

以上就是vue3.0引入百度地圖并標記點的詳細內(nèi)容,更多關(guān)于vue3.0百度地圖標記點的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue+canvas實現(xiàn)炫酷時鐘效果的倒計時插件(已發(fā)布到npm的vue2插件,開箱即用)

    vue+canvas實現(xiàn)炫酷時鐘效果的倒計時插件(已發(fā)布到npm的vue2插件,開箱即用)

    這篇文章主要介紹了vue+canvas實現(xiàn)炫酷時鐘效果的倒計時插件(已發(fā)布到npm的vue2插件,開箱即用) ,需要的朋友可以參考下
    2018-11-11
  • 詳解如何去除vue項目中的#——History模式

    詳解如何去除vue項目中的#——History模式

    這篇文章主要介紹了詳解如何去除vue項目中的#——History模式 ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-10-10
  • vue實現(xiàn)在線預(yù)覽office文件的示例代碼

    vue實現(xiàn)在線預(yù)覽office文件的示例代碼

    本文主要介紹了vue實現(xiàn)在線預(yù)覽office文件,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • vue為自定義路徑設(shè)置別名的方法

    vue為自定義路徑設(shè)置別名的方法

    這篇文章介紹了vue為自定義路徑設(shè)置別名的方法,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-11-11
  • vue項目中安裝less依賴的過程

    vue項目中安裝less依賴的過程

    這篇文章主要介紹了vue項目中安裝less依賴的過程,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • element-ui 中使用upload多文件上傳只請求一次接口

    element-ui 中使用upload多文件上傳只請求一次接口

    這篇文章主要介紹了element-ui 中使用upload多文件上傳只請求一次接口,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 詳解key在Vue3和Vue2的不同之處

    詳解key在Vue3和Vue2的不同之處

    key屬性是一個特殊的屬性,用于標識每個節(jié)點的唯一性。在Vue2.x版本中的key和Vue3.x版本中的key有很大的不同,那么在這篇文章中,我們將會討論Vue2中的key和Vue3中的key的區(qū)別
    2023-04-04
  • vue-cli5搭建vue項目的實現(xiàn)步驟

    vue-cli5搭建vue項目的實現(xiàn)步驟

    本文主要介紹了vue-cli5搭建vue項目的實現(xiàn)步驟,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • vue打包后,用后端接口報錯304、404問題

    vue打包后,用后端接口報錯304、404問題

    這篇文章主要介紹了vue打包后,用后端接口報錯304、404問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 默認瀏覽器設(shè)置及vue自動打開頁面的方法

    默認瀏覽器設(shè)置及vue自動打開頁面的方法

    今天小編就為大家分享一篇默認瀏覽器設(shè)置及vue自動打開頁面的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09

最新評論