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

在vue3項目中使用新版高德地圖的完整步驟

 更新時間:2023年02月27日 10:25:01   作者:開發(fā)那點事兒~  
項目需求需要引入地圖,對于目前最新的Vue3.0,無論是百度/高德/騰訊地圖目前還沒有適配,只有Vue?2.x版本的:?目前只有谷歌地圖的Vue3.0適配,下面這篇文章主要給大家介紹了關(guān)于如何在vue3項目中使用新版高德地圖的完整步驟,需要的朋友可以參考下

高德開發(fā)平臺 : 高德開放平臺 | 高德地圖API (amap.com)

1. 首先你要注冊好賬號登錄

2. 獲取key和密鑰 

自2021年12月02日升級,升級之后所申請的 key 必須配備安全密鑰 jscode 一起使用

NPM方式安裝和使用(基礎(chǔ)版):         

按 NPM 方式安裝使用 Loader :

npm i @amap/amap-jsapi-loader --save

在頁面中通過NPM 方式安裝的使用 :

<template>
    <div class="app-container">
        <div style="background-color: #ffffff;">
            <div id="container"></div>
        </div>
    </div>
</template>
 
<script setup>
import AMapLoader from '@amap/amap-jsapi-loader';
/*在Vue3中使用時,需要引入Vue3中的shallowRef方法(使用shallowRef進行非深度監(jiān)聽,
因為在Vue3中所使用的Proxy攔截操作會改變JSAPI原生對象,所以此處需要區(qū)別Vue2使用方式對地圖對象進行非深度監(jiān)聽,
否則會出現(xiàn)問題,建議JSAPI相關(guān)對象采用非響應式的普通對象來存儲)*/
import { shallowRef } from '@vue/reactivity';
import {ref} from "vue";
 
// const map = shallowRef(null);
const path = ref([]);
const current_position = ref([]);
 
function initMap() {
    window._AMapSecurityConfig = {
        securityJsCode: '8e920f73eb2e6880a92ea6662eefc476',
    }
    AMapLoader.load({
        key:"e4e3d44a98350790a1493450032bbec5", // 申請好的Web端開發(fā)者Key,首次調(diào)用 load 時必填
        version:"2.0", // 指定要加載的 JSAPI 的版本,缺省時默認為 1.4.15
        plugins:[''], // 需要使用的的插件列表,如比例尺'AMap.Scale'等
    }).then((AMap)=>{
        const map = new AMap.Map("container",{  //設置地圖容器id
            viewMode:"3D",    //是否為3D地圖模式
            zoom:13,           //初始化地圖級別
            center:[113.808299,34.791787], //初始化地圖中心點位置
        });
        
    }).catch(e=>{
        console.log(e);
    })
}
 
    initMap()
</script>
 
<style>
#container{
    padding:0px;
    margin: 0px;
    width: 100%;
    height: 800px;
}
</style>

完整代碼:

<template>
    <div class="app-container">
        <div style="background-color: #ffffff;">
            <div id="container"></div>
        </div>
    </div>
</template>
 
<script setup>
import AMapLoader from '@amap/amap-jsapi-loader';
/*在Vue3中使用時,需要引入Vue3中的shallowRef方法(使用shallowRef進行非深度監(jiān)聽,
因為在Vue3中所使用的Proxy攔截操作會改變JSAPI原生對象,所以此處需要區(qū)別Vue2使用方式對地圖對象進行非深度監(jiān)聽,
否則會出現(xiàn)問題,建議JSAPI相關(guān)對象采用非響應式的普通對象來存儲)*/
import { shallowRef } from '@vue/reactivity';
import {ref} from "vue";
 
// const map = shallowRef(null);
const path = ref([]);
const current_position = ref([]);
 
 
function initMap() {
    window._AMapSecurityConfig = {
        securityJsCode: '8e920f73eb2e6880a92ea6662eefc476',
    }
    AMapLoader.load({
        key:"e4e3d44a98350790a1493450032bbec5", // 申請好的Web端開發(fā)者Key,首次調(diào)用 load 時必填
        version:"2.0", // 指定要加載的 JSAPI 的版本,缺省時默認為 1.4.15
        // plugins:[''], // 需要使用的的插件列表,如比例尺'AMap.Scale'等
    }).then((AMap)=>{
        const map = new AMap.Map("container",{  //設置地圖容器id
            viewMode:"3D",    //是否為3D地圖模式
            zoom:13,           //初始化地圖級別
            center:[113.808299,34.791787], //初始化地圖中心點位置
        });
        // 添加插件
        AMap.plugin(["AMap.ToolBar", "AMap.Scale", "AMap.HawkEye","AMap.Geolocation","AMap.MapType","AMap.MouseTool"], function () {
            //異步同時加載多個插件
            // 添加地圖插件
            map.addControl(new AMap.ToolBar()); // 工具條控件;范圍選擇控件
            map.addControl(new AMap.Scale()); // 顯示當前地圖中心的比例尺
            map.addControl(new AMap.HawkEye()); // 顯示縮略圖
            map.addControl(new AMap.Geolocation()); // 定位當前位置
            map.addControl(new AMap.MapType()); // 實現(xiàn)默認圖層與衛(wèi)星圖,實時交通圖層之間切換
 
            // 以下是鼠標工具插件
            const mouseTool = new AMap.MouseTool(map);
            // mouseTool.rule();// 用戶手動繪制折線圖,測量距離
            mouseTool.measureArea(); // 測量面積
        });
        // 單擊
        map.on('click',(e) => {
            // lng ==> 經(jīng)度值  lat => 維度值
            current_position.value = [e.lnglat.lng,e.lnglat.lat];
            path.value.push([e.lnglat.lng,e.lnglat.lat]);
            // addMarker();
            // addPolyLine();
        })
 
 
        // 實例化點標記
        // 第一種(封成函數(shù)來觸發(fā))
        function addMarker() {
            const marker = new AMap.Marker({
                icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png",
                position: current_position.value, // 這里我們通過上面的點擊獲取經(jīng)緯度坐標,實時添加標記
                // 通過設置 offset 來添加偏移量
                offset: new AMap.Pixel(-26, -54),
            });
            marker.setMap(map);
        }
        // 第二種 直接寫死 position 的經(jīng)緯度值
        /*const marker = new AMap.Marker({
            icon: "//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png",
            position: [113.808299,34.791787],
            // 通過設置 offset 來添加偏移量
            offset: new AMap.Pixel(-26, -54),
        });
        marker.setMap(map);*/
 
 
        // 折線
        function addPolyLine() {
            const polyline = new AMap.Polyline({
                path: path.value,
                isOutline: true,
                outlineColor: "#ffeeff",
                borderWeight: 1,
                strokeColor: "#3366FF",
                strokeOpacity: 0.6,
                strokeWeight: 5,
                // 折線樣式還支持 'dashed'
                strokeStyle: "solid",
                // strokeStyle是dashed時有效
                // strokeDasharray: [10, 5],
                lineJoin: "round",
                lineCap: "round",
                zIndex: 50,
            });
            map.add([polyline]);
        }
 
 
 
    }).catch(e=>{
        console.log(e);
    })
}
 
initMap()
</script>
 
<style>
#container{
    padding:0px;
    margin: 0px;
    width: 100%;
    height: 800px;
}
</style>

地圖插件效果圖:

實例化點標記 :

第一種方式效果:

第二種方式效果:

矢量圖 --> 折線:

總結(jié)

到此這篇關(guān)于在vue3項目中使用新版高德地圖的文章就介紹到這了,更多相關(guān)vue3使用新版高德地圖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue中圖片轉(zhuǎn)base64格式實現(xiàn)方法

    vue中圖片轉(zhuǎn)base64格式實現(xiàn)方法

    這篇文章主要介紹了vue中圖片轉(zhuǎn)base64格式實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • vue2導航根據(jù)路由傳值,而改變導航內(nèi)容的實例

    vue2導航根據(jù)路由傳值,而改變導航內(nèi)容的實例

    下面小編就為大家?guī)硪黄獀ue2導航根據(jù)路由傳值,而改變導航內(nèi)容的實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-11-11
  • vue之el-menu-item如何更改導航菜單欄選中的背景顏色

    vue之el-menu-item如何更改導航菜單欄選中的背景顏色

    這篇文章主要介紹了vue之el-menu-item如何更改導航菜單欄選中的背景顏色問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-05-05
  • 淺析vue3響應式數(shù)據(jù)與watch屬性

    淺析vue3響應式數(shù)據(jù)與watch屬性

    這篇文章主要介紹了vue3響應式數(shù)據(jù)與watch屬性的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • 一文詳解vue各種權(quán)限控制與管理實現(xiàn)思路

    一文詳解vue各種權(quán)限控制與管理實現(xiàn)思路

    這篇文章主要為大家介紹了vue各種權(quán)限控制與管理的實現(xiàn)思路詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • 解決Vue運行項目報錯proxy?error:?could?not?proxy?request

    解決Vue運行項目報錯proxy?error:?could?not?proxy?request

    這篇文章主要給大家介紹了關(guān)于如何解決Vue運行項目報錯proxy?error:could?not?proxy?request的相關(guān)資料,Proxy Error指的是代理服務器無法正確處理請求的錯誤,需要的朋友可以參考下
    2023-08-08
  • vue自定義指令用法經(jīng)典實例小結(jié)

    vue自定義指令用法經(jīng)典實例小結(jié)

    這篇文章主要介紹了vue自定義指令用法,結(jié)合實例形式總結(jié)分析了vue自定義指令常見寫法與相關(guān)操作注意事項,需要的朋友可以參考下
    2019-03-03
  • vue3+ts數(shù)組去重方及reactive/ref響應式顯示流程分析

    vue3+ts數(shù)組去重方及reactive/ref響應式顯示流程分析

    這篇文章主要介紹了vue3+ts數(shù)組去重方法-reactive/ref響應式顯示,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-04-04
  • Vue3中事件總線的具體使用

    Vue3中事件總線的具體使用

    本文主要介紹了Vue3中事件總線的具體使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • Vuex之理解state的用法實例

    Vuex之理解state的用法實例

    本篇文章主要介紹了Vuex之理解state的用法實例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04

最新評論