Vue.js 加入高德地图的实现方法

news/2024/4/25 9:20:28/文章来源:https://blog.csdn.net/kangguang/article/details/128096331

一、功能需求

1.根据输入内容进行模糊查询,选择地址后在地图上插上标记,并更新经纬度坐标显示

2.在地图点击后,根据回传的左边更新地址信息和坐标显示

二、准备

1.申请高德地图账号,创建应用

 2.在应用管理中 获得key 和安全密钥

三、在webstorm中安装 

     

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

四、防止在使用中AMap无法识别问

        在eslintrc.js中加入配置:

       

  globals:{"AMap": "true"}

五、正式开发

1.创建页面

<template><div><label>消息管理</label><div style="margin-top: 20px"><div style="height:520px;"><div id="all" style="height:100%"><div class="posInput"><el-input style="width:100%"id="tipinput"class="form-control input-style"type="text"placeholder="请输入搜索地址"prefix-icon="el-icon-search"v-model="formatAdress"></el-input></div><div id="allmap"></div><div class="posSubmit"><el-form  ref="form"  label-width="85px" ><div class="btn_box" ><el-form-item label="经度:" ><el-input style="width:400px" disabled class="form-control input-style" type="text" v-model="longitude"> </el-input></el-form-item><el-form-item label="纬度:" ><el-input style="width:400px"  disabled class="form-control input-style" type="text" v-model="latitude"> </el-input></el-form-item></div></el-form></div></div></div></div></div>
</template>

2.页面样式

<style scoped>
#all{position: relative;
}
#allmap{width: 100%;  height: calc(100%  - 50px);font-family: "微软雅黑";
}
.posInput{position: absolute;z-index: 1;width: 80%;margin-top: 20px;  margin-left: 10%;
}
.posSubmit{position: absolute; z-index: 1; bottom: 0;margin-left: 5%;width: 90%;display: flex;  justify-content: flex-start; align-items: center;
}
.btn_box{width: 100%;height: 100%;display: flex;  ; align-items: center;
}
::v-deep .el-form-item{margin-bottom: 0 !important;
}
</style>

3.存储的数据项

data () {return {map: null,marker: null,startSeacrh: [],stratInfo: {},dprops: {zoom: 15},formatAdress: '',longitude: '', // 经度latitude: '', // 纬度}}

4.创建地图方法

   

  mounted () {this.initMap()},methods: {initMap () {const that = thisinit('allmap', that.dprops).then(AMap => {that.map = AMapthat.map.on('click', that.clickHandler) // 地图点击事件 可获取经纬度等信息initScaleTools(that.map, true, false)searchAutocomplete(that.map, 'tipinput', function (event) {that.handleStartSelect(event)})}).catch(err => {this.$message.error(err)})},clickHandler (event) {console.log(event, '起点经纬度 [lng,lat]')if (event.lnglat === '') {this.$message({type: 'warning',message: '该地点无经纬度数据,请输入具体一点的地点!',duration: 5 * 1000})return}if (this.marker) {this.map.remove(this.marker)this.marker = null}this.startSeacrh = []this.startSeacrh = [event.lnglat.lng, event.lnglat.lat]this.marker = new AMap.Marker({position: this.startSeacrh})this.map.add(this.marker)this.map.setCenter(this.startSeacrh)this.longitude = event.lnglat.lngthis.latitude = event.lnglat.latlet that = thisgetAddressByLngLat(this.startSeacrh, function (status, result) {if (status === 'complete') {that.formatAdress = result.regeocode.formattedAddresslet adrComponent = result.regeocode.addressComponentthat.stratInfo = {district: adrComponent.province,address: adrComponent.district,name: adrComponent.township + adrComponent.street + adrComponent.streetNumber,fullAdr: result.regeocode.formattedAddress}}})},handleStartSelect (event) {console.log(event, '起点经纬度 [lng,lat]')if (event.poi.location === '') {this.$message({type: 'warning',message: '该地点无经纬度数据,请输入具体一点的地点!',duration: 5 * 1000})return}if (this.marker) {this.map.remove(this.marker)this.marker = null}this.startSeacrh = []this.startSeacrh = [event.poi.location.lng, event.poi.location.lat]this.formatAdress = event.poi.district + event.poi.address + event.poi.namethis.longitude = event.poi.location.lngthis.latitude = event.poi.location.latthis.marker = new AMap.Marker({position: this.startSeacrh})this.map.add(this.marker)this.map.setCenter(this.startSeacrh)this.stratInfo = {district: event.poi.district,address: event.poi.address,name: event.poi.name,fullAdr: this.formatAdress}}}

5.封装好的js文件方法

  initMap.js

import AMapLoader from '@amap/amap-jsapi-loader'
window._AMapSecurityConfig = {securityJsCode: '安全密钥'
}
const initMap = async (config) => {return new Promise((resolve, reject) => {AMapLoader.load({'key': config.key,'version': '1.4.15','plugins': ['AMap.PolygonEditor' // 插件],'AMapUI': {'version': '1.1','plugins': []},'Loca': {'version': '1.3.2'}}).then((AMap) => {resolve(AMap)}).catch(err => {reject(err)})})
}
export default initMap

map.js

import initMap from './initMap.js'
export const init = (container, props) => {const config = {key: 'key'}return new Promise((resolve, reject) => {initMap(config).then(AMap => {resolve(new AMap.Map(container, { ...props }))}).catch(err => {reject(err)})})
}
/*** @param {*} map 地图实例* @param {Boolean} noScale 不需要比例尺  true表示不需要* @param {Boolean} noToolBar 不需要工具栏 true表示不需要*/
export const initScaleTools = (map, noScale, noToolBar) => {if (!noScale) {map.plugin(['AMap.Scale'], function () {var scale = new AMap.Scale()map.addControl(scale)})}if (!noToolBar) {map.plugin(['AMap.ToolBar'], function () {var tool = new AMap.ToolBar()map.addControl(tool)})}
}
//模糊查询
export const searchAutocomplete = (map, keyword, commpletHandle) => {map.clearMap()AMap.plugin(['AMap.PlaceSearch', 'AMap.Autocomplete'], function () {let autoOptions1 = { input: keyword, city: '全国' }let startAutoComplete = new AMap.Autocomplete(autoOptions1)AMap.PlaceSearch({map: map})AMap.event.addListener(startAutoComplete, 'select', commpletHandle)})
}/**** @param {String} LngLat 经纬度* @param {Function} callback 回调函数* @param {Object} otherProps 其他参数*/
export const getAddressByLngLat = (LngLat, callback, otherProps) => {AMap.plugin('AMap.Geocoder', function () {let geocoder = new AMap.Geocoder({...otherProps})geocoder.getAddress(LngLat, function (status, result) {callback(status, result)})})
}const mapJS = {init,initScaleTools,searchAutocomplete,getAddressByLngLat
}
export default mapJS

在文件中导入 map.js方法

import {init,initScaleTools,searchAutocomplete,getAddressByLngLat
} from '../../utils/map'

六、步骤总结

1.在mounted()中调用 initMap ()初始化地图

2.初始化成功后、添加事件监听:地图点击、模糊查询。添加放大缩小工具栏

init('allmap', that.dprops).then(AMap => {that.map = AMapthat.map.on('click', that.clickHandler) // 地图点击事件 可获取经纬度等信息initScaleTools(that.map, true, false)searchAutocomplete(that.map, 'tipinput', function (event) {that.handleStartSelect(event)})})

七:效果

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_38627.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

[附源码]Python计算机毕业设计Django常见Web漏洞对应POC应用系统

项目运行 环境配置&#xff1a; Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术&#xff1a; django python Vue 等等组成&#xff0c;B/S模式 pychram管理等等。 环境需要 1.运行环境&#xff1a;最好是python3.7.7&#xff0c;…

Python学习:json对象与string相互转换教程

首先要明确&#xff0c;python里有json这个库&#xff0c;但并没有json这个类&#xff0c;所以所谓的json对象本质上就是一个dict&#xff1b;而json这个库&#xff0c;用于实现dict到string、string到dict的互转。 更具体一点&#xff0c;json对象&#xff08;dict&#xff0…

Linux网络编程——IO多路复用

文章目录1&#xff0c;I/O模型2&#xff0c;阻塞I/O 模式2.1&#xff0c;读阻塞&#xff08;以read函数为例&#xff09;2.2&#xff0c;写阻塞3&#xff0c;非阻塞I/O模式3.1&#xff0c;非阻塞I/O模式的实现&#xff08;fcntl()函数、ioctl() 函数&#xff09;3.1.1&#xff…

leetcode 343. 整数拆分(动态规划)

题目链接&#xff1a;343. 整数拆分 动态规划 (1) 确定 dpdpdp 数组下标含义&#xff1a; dp[i]dp[i]dp[i]: 将 iii 拆分为至少两个正整数之后的最大乘积&#xff1b; (2) 确定递推公式&#xff1a; 当 i≥2i \ge 2i≥2 时, 设 jjj 是 iii 拆分出来的第一个正整数&#xff0c…

关于uni-app小程序接入微信登录

https://uniapp.dcloud.net.cn/api/plugins/login.html#login 官网上有关于uni.login()的说明&#xff0c;如果是要微信登录&#xff0c;则需要wx.login()。 小程序登录 | 微信开放文档 如下图&#xff0c;在小程序管理平台生成AppSecret&#xff0c;同时将AppId在HubilderX中…

swift @State @Published @ObservedObject sink

State struct ContentView: View {State private var isRain truevar body: some View {VStack {Image(systemName: isRain ? "cloud.rain.fill" : "sun.max.fill").resizable().frame(width: 100, height: 100)Text(isRain ? "我們淋著大雨不知何…

【PS-7】移动工具

目录 移动工具快捷键【v】&#xff08;英文状态&#xff09; 多文件间拖拽图层对象 快捷键【ALT】复制图层 【ALTSHIFT】只能垂直/水平/45角地去复制图层 4个方向键可以微调图层的位置 变换控件 对齐分布 【题外话】设置参考线颜色 【题外话】快捷键【F12】让已经动过…

实验三-----数据库

一、实验目的 1.掌握SQL Server Management Studio中SQL 查询操作&#xff1b; 2.掌握SQL 的单表查询命令&#xff1b; 3.掌握SQL 的连接查询操作&#xff1b; 4.掌握SQL 的嵌套查询操作&#xff1b; 5.掌握SQL 的集合查询操作。 二、实验环境 1&#xff0e;实验室名称&…

[附源码]计算机毕业设计springboot海南琼旅旅游网

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

前端单元测试,更进一步

前端测试2022 如果从 2014 年 Jest 的第一个版本发布开始计算&#xff0c;前端开发领域工程化的单元测试能力已经发展了八年有余。Jest 集成了 Jasmine 等以往各种被证明有效的单元测试框架和断言等工具&#xff0c;也可以用来完成包含外部接口服务的集成测试等。最近几年热门的…

xxl-job安装部署

一、简介 XXL-JOB是一个分布式任务调度平台&#xff0c;其核心设计目标是开发迅速、学习简单、轻量级、易扩展。现已开放源代码并接入多家公司线上产品线&#xff0c;开箱即用。 中文文档English Documentation 二、安装 xxl-job需要的提前安装好以下环境&#xff1a;jdk、m…

INTERSPEECH 2022|CALM: 基于对比学习的表现力语音合成跨模态说话风格建模【语音之家】

本文由清华大学与腾讯科技有限公司和香港中文大学合作&#xff0c;并 在腾讯公司落地应用 。 说话风格建模对于表现力语音合成具有重要作用。 现有基于参考音频提取风格表征的方法通常利用文本的语义相似度进行参考音频选择&#xff0c;忽略了语义信息和说话风格的差异性。 本文…

大厂都在用MyBatis,跳槽的时候MyBatis更是面试必问的内容,那你对于MyBatis又掌握了多少呢?这份MyBatis源码解析值得拥有!

MyBatis作为一个流行的半自动ORM框架&#xff0c;里面融合了许多优秀的设计理念&#xff0c;分析其源码骨架能够帮你建立良好的项目设计经验。由于其比较复杂&#xff0c;我会分成几篇来讲&#xff0c;一起踏上征服的旅程吧&#xff01; 首先把MyBatis源码包导入到idea&#x…

python+django汽车租赁系统pycharm项目

目录 1 绪论 1 1.1课题背景 1 1.2课题研究现状 1 1.3初步设计方法与实施方案 2 1.4本文研究内容 2 4 2.3 B/S结构简介 4 2.4MySQL数据库 5 3 系统分析 6 3.1系统可行性分析 6 3.1.1经济可行性 6 3.1.2技术可行性 6 3.1.3运行可行性 6 3.2系统现状分析 6 3.3功能需求分析 7 …

Apollo 应用与源码分析:Monitor监控-软件监控-时间延迟监控

目录 代码 分析 RunOnce 函数分析 UpdateState函数分析 发送时间延迟报告函数分析 备注 代码 class LatencyMonitor : public RecurrentRunner {public:LatencyMonitor();void RunOnce(const double current_time) override;bool GetFrequency(const std::string& ch…

Git---idea中git的基本操作

idea中使用git仓库 idea中配置git仓库&#xff1a; 首先idea配置git仓库的位置 配置完成之后&#xff0c;有两种创建仓库的方式 从本地配置git仓库&#xff1a; idea本身设置好的&#xff0c;直接下一步就好 从远程克隆仓库&#xff1a; 如果远程仓库没有的话可以绑定完…

CDMP考试时间与报名方式

CDMP“数据管理专业人士认证”证书国际通用&#xff0c;行业认可度极高&#xff0c;是一项涵盖学历教育、工作经验和专业知识考试在内的综合资格认证&#xff0c;也是 目前全球唯一数据管理方面权威性认证 。CDMP考试时间是什么时候&#xff1f;怎样报名&#xff1f;今天小编来…

从ChargePoint到能链智电,充电服务商的价值创新

近日&#xff0c;吉林长春出租车雨雪之中排队换电艰难的视频引起热议。 新能源汽车充换电困难&#xff0c;一方面说明电池在寒冷天气下的性能有优化空间&#xff0c;另一方面也反映出国内新能源汽车配套基础设施仍然存在较大需求缺口。 充电基础设施建设对新能源汽车推广意义…

使用Spark的foreach算子及UDTF函数实现MySQL数据的一对多【Java】

使用Spark的foreach算子及UDTF函数实现MySQL数据的一对多【Java】 背景 我们的数仓项目中遇到了这样一种场景&#xff0c;脱敏后内容大致如下&#xff1a; col1col2time1time2a1b12022-01-01 00:00:002022-01-05 00:00:00a2b22022-01-28 00:00:002022-02-03 00:00:00a3b3202…

设计模式——模板方法模式

模板方法模式 一、基本思想 定义一个操作中的算法骨架&#xff0c;而将算法的一些步骤延迟到子类中&#xff0c;使得子类可以不改变该算法结构的情况下重定义该算法的某些特定步骤。 二、应用场景 算法的整体步骤很固定&#xff0c;但其中个别部分易变时&#xff0c;这时候…