Vue3,setup,高德地图api,实现地图搜索查询地址功能

本文主要是介绍Vue3,setup,高德地图api,实现地图搜索查询地址功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果图:

高德地图搜索api支持模糊搜索.

高德地图key申请:

安装依赖:npm i @amap-jsapi-loader -- s

地图组件页面:

<template><div class="main"><div class="form"><!--搜索框--><input type="text" class="input" v-model="address" id="tipinput"     @keyup.enter="select"></div><!--查询列表,高德地图api绑定id--><div class="list" id="list"></div><!--地图,需要设置宽高--><div class="map" id="gd_map_d"></div></div>
</template><script setup>
import AMapLoader from '@amap/amap-jsapi-loader';
//data
const { proxy } = getCurrentInstance();
const address = ref("");
let geocoder = null;
let MyMap = null;
let map = null;
//methods
const select = () => {//构造地点查询类var placeSearch = new MyMap.PlaceSearch({pageSize: 3, // 单页显示结果条数pageIndex: 1, // 页码city: "010", // 兴趣点城市citylimit: false,  //是否强制限制在设置的城市内搜索map: map, // 展现结果的地图实例panel: "list", // 结果列表将在此容器中进行展示。autoFitView: false // 是否自动调整地图视野使绘制的 Marker点都处于视口的可见范围});//关键字查询placeSearch.search(proxy.address);
}
const getAddress = () => {let cc = map.getCenter();return new Promise((resolve, reject) => {geocoder.getAddress([cc.lng, cc.lat], (status, result) => {if (result.regeocode.formattedAddress) {resolve(result.regeocode.formattedAddress)} else {resolve("");}})})
}
//mapinit
window._AMapSecurityConfig = {securityJsCode: '填写高德地图Web端(JS API)申请的密钥',
}
AMapLoader.load({"key": "填写高德地图Web端(JS API)申请的key", // 申请好的Web端开发者Key"version": "2.0",   // 指定要加载的 JSAPI 的版本,缺省时默认为 1.4.15"plugins": ['AMap.AutoComplete', 'AMap.PlaceSearch', 'AMap.Geocoder'],           // 需要使用的的插件列表,如比例尺'AMap.Scale'等
}).then((AMap) => {MyMap = AMap;//保存AMapinit();
}).catch(e => {console.log(e);
})
const init = () => {//绘制MyMap实例地图map = new MyMap.Map('gd_map_d', {zoom: 14, //初始地图级别center: [121.473432, 31.22919],resizeEnable: true })geocoder = new MyMap.Geocoder({city: "010", //城市设为北京,默认:“全国”});var auto = new MyMap.AutoComplete({input: "tipinput"});
}
defineExpose({getAddress  //将事件暴露出去
})
</script>
<style scoped lang="scss">
.main {width: 100%;height: 350px;position: relative;.map {width: 100%;height: 100%;}.form {position: absolute;left: 10px;top: 10px;z-index: 999;.input {width: 180px;line-height: 30px;padding-left: 5px;box-shadow: 0 2px 6px 0 rgb(114 124 245 / 50%);outline: none;border-radius: 5px;border: none;}}.list {position: absolute;top: 10px;right: 10px;height: 300px;width: 240px;z-index: 999;.li {line-height: 25px;}}
}
</style>

父组件页面

<template><el-dialog v-model="dialogVisible2" title="地图" width="50%" :close-on-click-modal="false"><div class="amap-wrapper"><div id="Amap"><MyMap ref="mymap"></MyMap></div></div><template #footer><span class="dialog-footer"><el-button type="primary" @click="getAddress">保存</el-button><el-button @click="dialogVisible = false">取消</el-button></span></template>
</el-dialog>
</template><script setup>
import { computed } from '@vue/reactivity';
import { getCurrentInstance, ref, reactive } from 'vue';
const { proxy } = getCurrentInstance();
const dialogVisible = ref(true);const getAddress = () => {proxy.$refs.mymap.getAddress().then(res => {console.log(res);})
}
</script>

这篇关于Vue3,setup,高德地图api,实现地图搜索查询地址功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/790332

相关文章

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

Django之定时任务django-crontab的实现

《Django之定时任务django-crontab的实现》Django可以使用第三方库如django-crontab来实现定时任务的调度,本文主要介绍了Django之定时任务django-cront... 目录crontab安装django-crontab注册应用定时时间格式定时时间示例设置定时任务@符号

MySQL复合查询从基础到多表关联与高级技巧全解析

《MySQL复合查询从基础到多表关联与高级技巧全解析》本文主要讲解了在MySQL中的复合查询,下面是关于本文章所需要数据的建表语句,感兴趣的朋友跟随小编一起看看吧... 目录前言:1.基本查询回顾:1.1.查询工资高于500或岗位为MANAGER的雇员,同时还要满足他们的姓名首字母为大写的J1.2.按照部门

Python中edge-tts实现便捷语音合成

《Python中edge-tts实现便捷语音合成》edge-tts是一个功能强大的Python库,支持多种语言和声音选项,本文主要介绍了Python中edge-tts实现便捷语音合成,具有一定的参考价... 目录安装与环境设置文本转语音查找音色更改语音参数生成音频与字幕总结edge-tts 是一个功能强大的

Java实现按字节长度截取字符串

《Java实现按字节长度截取字符串》在Java中,由于字符串可能包含多字节字符,直接按字节长度截取可能会导致乱码或截取不准确的问题,下面我们就来看看几种按字节长度截取字符串的方法吧... 目录方法一:使用String的getBytes方法方法二:指定字符编码处理方法三:更精确的字符编码处理使用示例注意事项方

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

Android 实现一个隐私弹窗功能

《Android实现一个隐私弹窗功能》:本文主要介绍Android实现一个隐私弹窗功能,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 效果图如下:1. 设置同意、退出、点击用户协议、点击隐私协议的函数参数2. 《用户协议》、《隐私政策》设置成可点击的,且颜色要区分出来res/l

spring IOC的理解之原理和实现过程

《springIOC的理解之原理和实现过程》:本文主要介绍springIOC的理解之原理和实现过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、IoC 核心概念二、核心原理1. 容器架构2. 核心组件3. 工作流程三、关键实现机制1. Bean生命周期2.

Redis实现分布式锁全解析之从原理到实践过程

《Redis实现分布式锁全解析之从原理到实践过程》:本文主要介绍Redis实现分布式锁全解析之从原理到实践过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、背景介绍二、解决方案(一)使用 SETNX 命令(二)设置锁的过期时间(三)解决锁的误删问题(四)Re