使用Vue3+ElementPlus+高德地图实现在浏览器中搜索地点并被标记在地图中

本文主要是介绍使用Vue3+ElementPlus+高德地图实现在浏览器中搜索地点并被标记在地图中,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果描述

在页面的输入框中输入想要查询的地点,在输入框的下方会提示跟输入的关键字有关地点,然后按下回车键或者选择下方罗列的地点即可让地图跳转到搜索的位置。

效果展示

页面渲染完成的时候
输入想要查询的地点
按下回车键之后

代码实现

<template><div><div id="container" style="width: 100%; height: 500px"></div><div id="myPageTop"><!-- clearable:是否显示清除按钮,只有当 type 不是 textarea时生效 --><!-- @keyup.enter:当回车键按下的时候触发 --><el-inputid="tipinput"v-model="searchKeyword"placeholder="请输入关键字"clearable@keyup.enter="searchLocation"></el-input></div></div>
</template><script>
import { onMounted, ref } from "vue";
// 引入高德地图API
import { load } from "@amap/amap-jsapi-loader";export default {setup() {// 用户输入的地点关键字const searchKeyword = ref("");let map = null; //初始化地图let placeSearch = null; // 声明placeSearch变量onMounted(async () => {// 设置高德地图的安全配置【此处一定要配置,否则会搜索失败】window._AMapSecurityConfig = {securityJsCode: "换成你的密钥",};// 初始化地图map = await initMap();// 加载插件并绑定事件({ placeSearch } = await loadPluginsAndBindEvents(map)); // 返回并解构出placeSearch});// 初始化高德地图实例async function initMap() {// 加载搞得地图API,包括指定的版本和插件const AMap = await load({key: "换成你的key", // 高德地图API Keyversion: "2.0",plugins: ["AMap.PlaceSearch", "AMap.AutoComplete"],});// 创建地图实例,设置容器ID和允许自适应窗口大小return new AMap.Map("container", {resizeEnable: true,});}// 加载插件并绑定事件async function loadPluginsAndBindEvents(map) {const autoOptions = {input: "tipinput", //绑定到输入框的ID};// 创建自动完成实例const auto = new AMap.AutoComplete(autoOptions);// 创建地点搜索实例,关联到地图const ps = new AMap.PlaceSearch({map: map,});// 绑定自动完成的选中事件,根据选中的地点设置城市并执行搜索auto.on("select", (e) => {ps.setCity(e.poi.adcode); //设置搜索城市为选中地点的城市编码ps.search(e.poi.name); //搜索选中地点的名称});return { placeSearch: ps }; // 返回placeSearch实例}// 处理地点搜索逻辑async function searchLocation() {// 判断用户是否输入了关键字if (!searchKeyword.value.trim()) {ElMessage.error("请输入搜索内容!");return;}// 执行地点搜索,并处理搜索结果placeSearch.search(searchKeyword.value, (status, result) => {console.log(status, result);if (status === "complete" && result.info === "OK") {// 如果搜索成功且有搜索结果if (result.poiList.pois.length > 0) {// 取第一个搜索结果,设置地图中心和缩放级别const poi = result.poiList.pois[0];map.setCenter([poi.location.lng, poi.location.lat]);map.setZoom(15); //缩放级别} else {ElMessage.error("未找到相关地点!");}} else {ElMessage.error("搜索失败!");}});}return {searchKeyword,searchLocation,};},
};
</script><style>
/* 引入高德地图样式 */
@import url("https://cache.amap.com/lbs/static/main1119.css");
</style>

设置高德地图Key

登录高德地图开放平台

点击标题栏中的控制台,进入到控制台界面

点击应用管理 ==》我的应用,如果有应用的话创建个应用,也可以用之前的应用,然后点击添加Key,写入key的名称 ==》服务平台选择Web端(JS API) ==》勾选阅读并同意 ==》点击提交按钮,即可创建一个新的Key

这篇关于使用Vue3+ElementPlus+高德地图实现在浏览器中搜索地点并被标记在地图中的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

C#中Guid类使用小结

《C#中Guid类使用小结》本文主要介绍了C#中Guid类用于生成和操作128位的唯一标识符,用于数据库主键及分布式系统,支持通过NewGuid、Parse等方法生成,感兴趣的可以了解一下... 目录前言一、什么是 Guid二、生成 Guid1. 使用 Guid.NewGuid() 方法2. 从字符串创建

Python使用python-can实现合并BLF文件

《Python使用python-can实现合并BLF文件》python-can库是Python生态中专注于CAN总线通信与数据处理的强大工具,本文将使用python-can为BLF文件合并提供高效灵活... 目录一、python-can 库:CAN 数据处理的利器二、BLF 文件合并核心代码解析1. 基础合

Python使用OpenCV实现获取视频时长的小工具

《Python使用OpenCV实现获取视频时长的小工具》在处理视频数据时,获取视频的时长是一项常见且基础的需求,本文将详细介绍如何使用Python和OpenCV获取视频时长,并对每一行代码进行深入解析... 目录一、代码实现二、代码解析1. 导入 OpenCV 库2. 定义获取视频时长的函数3. 打开视频文

golang版本升级如何实现

《golang版本升级如何实现》:本文主要介绍golang版本升级如何实现问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录golanwww.chinasem.cng版本升级linux上golang版本升级删除golang旧版本安装golang最新版本总结gola

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Mysql实现范围分区表(新增、删除、重组、查看)

《Mysql实现范围分区表(新增、删除、重组、查看)》MySQL分区表的四种类型(范围、哈希、列表、键值),主要介绍了范围分区的创建、查询、添加、删除及重组织操作,具有一定的参考价值,感兴趣的可以了解... 目录一、mysql分区表分类二、范围分区(Range Partitioning1、新建分区表:2、分

MySQL 定时新增分区的实现示例

《MySQL定时新增分区的实现示例》本文主要介绍了通过存储过程和定时任务实现MySQL分区的自动创建,解决大数据量下手动维护的繁琐问题,具有一定的参考价值,感兴趣的可以了解一下... mysql创建好分区之后,有时候会需要自动创建分区。比如,一些表数据量非常大,有些数据是热点数据,按照日期分区MululbU

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注