高德地圖在Vue3中的使用方法

1.地圖初始化

????????容器創建:通過?<div>?標簽定義地圖掛載點。

<div id="container" style="height: 300px; width: 100%; margin-top: 10px;"></div>

????????密鑰配置:綁定高德地圖安全密鑰,確保 API 合法調用。

????????參數配置:定義地圖縮放比例、初始中心點經緯度(數組格式?[lng, lat])。

????????標記點初始化:創建?Marker?實例用于后續定位

// 初始化地圖(完全異步化)
const initMap = async () => {// 確保DOM已渲染await nextTick();// 檢查容器是否存在const container = document.getElementById('container');if (!container) {console.error('地圖容器不存在,可能對話框尚未完全渲染');return false;}if (mapLoaded.value && map.value) return true; // 如果已經加載過且地圖已初始化,直接返回try {// 設置安全配置(window as any)._AMapSecurityConfig = {securityJsCode: '76f83426ac3692c440bc1efd2b15fff6'};// 動態加載高德地圖JSawait new Promise((resolve, reject) => {if ((window as any).AMap) return resolve(true); // 如果已經加載過,直接返回const script = document.createElement('script'); // 創建script標簽script.src = 'https://webapi.amap.com/maps?v=2.0&key=f10b74bad0d89466b9e174aaefb9a3f7&plugin=AMap.Geocoder';script.onload = resolve; // 加載成功后調用 resolve 函數script.onerror = reject; // 加載失敗后調用 reject 函數document.head.appendChild(script);});// 再次檢查容器是否存在 (id 是唯一的)if (!document.getElementById('container')) {console.error('地圖容器在腳本加載后不存在');return false;}// 初始化地圖map.value = new (window as any).AMap.Map('container', {zoom: 13, // 初始縮放級別為 13center: [116.397428, 39.90923], // 初始中心點為 [116.397428, 39.90923],即天安門廣場});// 初始化標記marker.value = new (window as any).AMap.Marker({map: map.value});mapLoaded.value = true;return true; // 返回 true 表示成功加載} catch (error) {console.error('地圖初始化失敗:', error);proxy?.$modal.msgError('地圖加載失敗');return false; // 返回 false 表示加載失敗}
};

2.地址選擇與解析

級聯選擇器:選擇省、市、縣三級行政區(普通省份為三級,直轄市可能缺少縣級)。

詳細地址輸入:用戶手動補充街道、樓棟等詳細信息。

地址合并:將級聯選擇結果與輸入框內容拼接成完整地址字符串。

地理編碼:調用高德地圖 API 將地址轉為經緯度。

更新標記點:將解析后的經緯度更新到地圖標記。

防抖函數:控制高頻觸發的事件或函數的執行頻率,確保在事件連續快速觸發時,只在最后一次觸發后的一段時間內執行一次目標操作。

// 防抖函數
const debounce = (fn: Function, delay: number) => {let timer: ReturnType<typeof setTimeout>; // 用于存儲定時器的返回值return function (this: any, ...args: any[]) {clearTimeout(timer); // 清除上一次的定時器timer = setTimeout(() => fn.apply(this, args), delay); // 設置新的定時器};
};
// 處理地址選擇變化(核心邏輯)
const handleAddressChange = debounce(async () => {try {await initMap();const selectedLabels = form.value.addressArray?.map(code => codeToText[code]) || []; // 獲取選中的省市區const detailAddress = form.value.addressDetail?.trim() || ''; // 獲取詳細地址const fullAddress = [...selectedLabels, detailAddress].join(''); // 拼接完整地址// 這里賦值給addressform.value.address = fullAddress;if (!fullAddress) return; // 如果地址為空,不進行解析const geocoder = new (window as any).AMap.Geocoder({city: selectedLabels[0] || '' // 根據選中的省設置地圖上的城市});interface GeocoderResult {status: string; // 狀態碼result: any; // 解析結果}const { status, result } = await new Promise<GeocoderResult>((resolve, reject) => {geocoder.getLocation(fullAddress, (status, result) => {if (status === 'complete') resolve({ status, result }); // 成功解析else reject(new Error(result?.info || '地址解析失敗')); // 失敗});});if (status === 'complete' && result.geocodes?.length) {// geocodes 是高德地圖API返回的地理編碼結果數組,它包含了地址解析后的地理信息。/** geocodes:[{*      location : 包含經緯度坐標(lng, lat)*      formattedAddress : 格式化后的完整地址*      addressComponent : 地址組成信息(省、市、區等)*      level : 地址匹配的精確度級別* }]*/const lnglat = result.geocodes[0].location;map.value?.setCenter(lnglat); // 將地圖中心移動到解析后的位置marker.value?.setPosition(lnglat); // 將標記移動到解析后的位置// 更新表單坐標form.value.longitude = lnglat.lng;form.value.latitude = lnglat.lat;}} catch (error) {console.error('地址解析錯誤:', error);proxy?.$modal.msgError(error.message);}
}, 500);

3. 直轄市特殊處理以及回顯

問題背景:直轄市(如北京、上海)的級聯數據層級缺失(如?北京市 -> 北京市)。
直接拼接會導致地址重復(如?北京市北京市朝陽區xx路)。

修復邏輯:通過判斷省、市名稱是否相同,動態修正地址字符串

/** 修改按鈕操作 */
const handleUpdate = async (row?: TenantVO) => {reset();await getTenantPackage();const _id = row?.id || ids.value[0];const res = await getTenant(_id);Object.assign(form.value, res.data);// 確保對話框完全打開dialog.visible = true;dialog.title = '修改租戶';try {// 等待地圖初始化完成await initMap();// 判讀經緯度是否有值if (form.value.longitude && form.value.latitude) {map.value?.setCenter([form.value.longitude, form.value.latitude]); // 將地圖中心移動到解析后的位置marker.value?.setPosition([form.value.longitude, form.value.latitude]); //  將標記移動到解析后的位置// 執行逆地理編碼// 傳入經緯度數組 [form.value.longitude, form.value.latitude] ,獲取地址信息const geocoder = new (window as any).AMap.Geocoder();const { status, result } = await new Promise((resolve, reject) => {geocoder.getAddress([form.value.longitude, form.value.latitude], (status, result) => {if (status === 'complete') resolve({ status, result });else reject(new Error(result?.info || '地址解析失敗'));});});if (status === 'complete' && result.regeocode) {const address = result.regeocode.formattedAddress;const addressComponent = result.regeocode.addressComponent;const province = addressComponent.province;const city = addressComponent.city || province; // 如果沒有city,使用province代替 因為直轄市沒有city字段/*** addressComponent = {*    province: "北京市",*    city: "", // 直轄市可能沒有city字段*    district: "朝陽區"*   }*/const district = addressComponent.district;// 更新表單中的地址信息form.value.address = address;// 將省市區轉換為級聯選擇器需要的code格式const findCode = (name, data) => {// name 為省市區名稱,data 為 regionData 數據包含了中國的省、市、區三級行政區劃信息for (const item of data) {if (item.label === name) return item.value;if (item.children && item.children.length > 0) {const childCode = findCode(name, item.children); // 遞歸查找子級if (childCode) return childCode; // 如果找到了,返回code}}return null;};const provinceCode = findCode(province, regionData); // 查找省的codelet cityCode = findCode(city, regionData); // 查找市的codeconst districtCode = findCode(district, regionData); // 查找區的code// 設置級聯選擇器值if (provinceCode && cityCode && districtCode) {cityCode = cityCode.length == 2 ? cityCode + '01' : cityCode; // 給直轄市的市code添加01form.value.addressArray = [provinceCode, cityCode, districtCode];}// 設置詳細地址// 需要三元運算符,因為直轄市會重復顯示,所以進行判斷 直轄市的 province 和 city 是一樣的province == city ? form.value.addressDetail = address.replace(`${province}${district}`, '') : form.value.addressDetail = address.replace(`${province}${city}${district}`, '');// console.log(province, city, district);}} else {// 默認顯示天安門廣場const tiananmenPosition = [116.397428, 39.90923];map.value?.setCenter(tiananmenPosition);marker.value?.setPosition(tiananmenPosition);}} catch (error) {console.error('地圖操作錯誤:', error);if (!form.value.longitude || !form.value.latitude) {// 如果是沒有經緯度的情況,不顯示錯誤提示return;}proxy?.$modal.msgError('地圖加載失敗,請檢查網絡連接或稍后再試');}
};

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/81185.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/81185.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/81185.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

RabbitMQ發布訂閱模式深度解析與實踐指南

目錄 RabbitMQ發布訂閱模式深度解析與實踐指南1. 發布訂閱模式核心原理1.1 消息分發模型1.2 核心組件對比 2. 交換機類型詳解2.1 交換機類型矩陣2.2 消息生命周期 3. 案例分析與實現案例1&#xff1a;基礎廣播消息系統案例2&#xff1a;分級日志處理系統案例3&#xff1a;分布式…

中小型培訓機構都用什么教務管理系統?

在教育培訓行業快速發展的今天&#xff0c;中小型培訓機構面臨著學員管理復雜、課程體系多樣化、教學效果難以量化等挑戰。一個高效的教務管理系統已成為機構運營的核心支撐。本文將深入分析當前市場上適用于中小型培訓機構的教務管理系統&#xff0c;重點介紹愛耕云這一專業解…

C++虛函數食用筆記

虛函數定義與作用&#xff1a; virtual關鍵字聲明虛函數&#xff0c;虛函數可被派生類override(保證返回類型與參數列表&#xff0c;名字均相同&#xff09;&#xff0c;從而通過基類指針調用時&#xff0c;實現多態的功能 virtual關鍵字: 將函數聲明為虛函數 override關鍵…

運算放大器相關的電路

1運算放大器介紹 解釋&#xff1a;運算放大器本質就是一個放大倍數很大的元件&#xff0c;就如上圖公式所示 Vp和Vn相差很小但是放大后輸出還是會很大。 運算放大器不止上面的三個引腳&#xff0c;他需要獨立供電&#xff1b; 如圖比較器&#xff1a; 解釋&#xff1a;Vp&…

華為OD機試真題——通信系統策略調度(用戶調度問題)(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳實現

2025 B卷 100分 題型 本專欄內全部題目均提供Java、python、JavaScript、C、C++、GO六種語言的最佳實現方式; 并且每種語言均涵蓋詳細的問題分析、解題思路、代碼實現、代碼詳解、3個測試用例以及綜合分析; 本文收錄于專欄:《2025華為OD真題目錄+全流程解析+備考攻略+經驗分…

Ubuntu 系統默認已安裝 python,此處只需添加一個超鏈接即可

步驟 1&#xff1a;確認 Python 3 的安裝路徑 查看當前 Python 3 的路徑&#xff1a; which python3 輸出類似&#xff1a; /usr/bin/python3 步驟 2&#xff1a;創建符號鏈接 使用 ln -s 創建符號鏈接&#xff0c;將 python 指向 python3&#xff1a; sudo ln -s /usr/b…

深度學習-分布式訓練機制

1、分布式訓練時&#xff0c;包括train.py的全部的代碼都會在每個gpu上運行嗎&#xff1f; 在分布式訓練&#xff08;如使用 PyTorch 的 DistributedDataParallel&#xff0c;DDP&#xff09;時&#xff0c;每個 GPU 上運行的進程會執行 train.py 的全部代碼&#xff0c;但通過…

yarn的介紹

### Yarn 的基本概念 Yarn 是 Hadoop 生態系統中的一個重要組成部分&#xff0c;它是一種分布式資源管理框架&#xff0c;旨在為大規模數據處理提供高效的資源管理和調度能力。以下是關于 Yarn 的一些核心概念&#xff1a; #### 1. **Yarn 的定義** Yarn 是一個資源調度平臺&a…

Spring-messaging-MessageHandler接口實現類ServiceActivatingHandler

ServiceActivatingHandler實現了MessageHandler接口&#xff0c;所以它是一個MessageHandler&#xff0c;在spring-integration中&#xff0c;它也叫做服務激活器&#xff08;Service Activitor&#xff09;&#xff0c;因為這個類是依賴spring容器BeanFactory的&#xff0c;所…

快速入門深度學習系列(2)----損失函數、邏輯回歸、向量化

針對深度學習入門新手目標不明確 知識體系雜亂的問題 擬開啟快速入門深度學習系列文章的創作 旨在幫助大家快速的入門深度學習 寫在前面&#xff1a; 本系列按照吳恩達系列課程順序發布(說明一下為什么不直接看原筆記 因為內容太多 沒有大量時間去閱讀 所有作者需要一次梳理…

KingBase問題篇

安裝環境 操作系統&#xff1a;CentOS7 CPU&#xff1a;X86_64架構 數據庫&#xff1a;KingbaseES_V008R006C009B0014_Lin64_install.iso 項目中遇到的問題 Q1. 執行sql中有字符串常量&#xff0c;且用雙引號包裹&#xff0c;執行報錯 A1. 默認KingBase不認雙引號&#xff0…

瀕危仙草的重生敘事:九仙尊米斛花節如何以雅集重構中醫藥文化IP

五月的霍山深處,層巒疊翠之間,中華仙草霍山米斛迎來一年一度的花期。九仙尊以“斛韻雅集,春野茶會”為主題,舉辦為期半月的米斛花文化節,融合中醫藥文化、東方美學與自然體驗,打造一場跨越古今的沉浸式文化盛宴。活動涵蓋古琴雅集、書法創作、茶道冥想、詩歌吟誦、民族歌舞等多…

LeetCode100.1 兩數之和

今天晚上看了許多關于未來計算機就業的視頻&#xff0c;有種正被販賣焦慮的感覺&#xff0c;翻來覆去下決定先做一遍leetcode100給自己降降溫&#xff0c;打算每周做四題&#xff0c;盡量嘗試不同的方法與不同的語言。 一開始想到的是暴力解法&#xff0c;兩層循環。數據量為1e…

python制造一個報錯

以下是用Python制造常見錯誤的示例及解析&#xff0c;涵蓋不同錯誤類型&#xff0c;便于理解調試原理&#xff1a; 一、語法錯誤 (SyntaxError) # 錯誤1&#xff1a;缺少冒號 if Trueprint("這行不會執行")# 錯誤2&#xff1a;縮進錯誤 def func(): print("未對…

idea整合maven環境配置

idea整合maven 提示&#xff1a;幫幫志會陸續更新非常多的IT技術知識&#xff0c;希望分享的內容對您有用。本章分享的是springboot的使用。前后每一小節的內容是存在的有&#xff1a;學習and理解的關聯性。【幫幫志系列文章】&#xff1a;每個知識點&#xff0c;都是寫出代碼…

Node.js中那些常用的進程通信方式

文章目錄 1 什么是子進程?2 核心方法詳解2.1 `child_process.spawn(command, [args], [options])`2.2 `child_process.exec(command, [options], callback)`2.3 `child_process.execFile(file, [args], [options], callback)`2.4 `child_process.fork(modulePath, [args], [op…

Vue3吸頂導航的實現

吸頂導航實現 【實現目標】&#xff1a; 在Layout頁面中&#xff0c;瀏覽器上下滾動時&#xff0c;距離頂部距離大于80px吸頂導航顯示&#xff0c;小于則隱藏。 【實現過程】&#xff1a; 通過layout接口獲取分類列表內容并使用categorystore進行狀態管理&#xff0c;獲取到…

雙向長短期記憶網絡-BiLSTM

5月14日復盤 二、BiLSTM 1. 概述 雙向長短期記憶網絡&#xff08;Bi-directional Long Short-Term Memory&#xff0c;BiLSTM&#xff09;是一種擴展自長短期記憶網絡&#xff08;LSTM&#xff09;的結構&#xff0c;旨在解決傳統 LSTM 模型只能考慮到過去信息的問題。BiLST…

2025年Flutter項目管理技能要求

在2025年&#xff0c;隨著Flutter技術的廣泛應用和項目復雜度的提升&#xff0c;項目管理的重要性愈發凸顯。Flutter項目管理不僅需要技術能力&#xff0c;還需要良好的溝通、協調、規劃和執行能力。本文將詳細探討2025年Flutter項目管理應具備的技能要求&#xff0c;幫助項目管…

OpenCV CUDA模塊中逐元素操作------數學函數

操作系統&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 編程語言&#xff1a;C11 算法描述 在OpenCV的CUDA模塊中&#xff0c;確實存在一系列用于執行逐元素數學運算的函數&#xff0c;包括指數、對數、平方根等。這些函數對于高級圖像處…