项目中,需要实现获取当前位置的经纬度,或者搜索某个位置并获取经纬度信息,我使用的的是vue,地图使用的是百度地图。

默认自动获取当前位置经纬度

拖动小红标 获取经纬度

关键词 查询获取经纬度

前期准备

首先,我们需要取百度官方申请一个地图api秘钥,登录百度帐号 进入后在应用管理,我的应用去申请即可。

申请好以后,我们打开vue项目中public文件下的index.html文件,拼接百度AK值并引入

<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=WFKACU6v7aiUdnkgtMCqdWBZC68KpUXv"></script>

如上所示,红色区域为AK值,自行拼接自己的,可以设置权限为公开或者针对网址白名单。

<script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0&ak=WFKACU6v7aiUdnkgtMCqdWBZC68KpUXv"></script>

我使用了elementui的弹窗,输入框,提示,如果你没使用elementui,记得更换哦!

HTML代码

<template><div><el-dialog@close="clearDialog":close-on-click-modal="false":title="text"style="text-align: left":visible.sync="popup"width="30%"><div class="form-layer"><el-form label-width="100px" size="mini"><el-form-item label="获取定位"><el-button type="primary" @click="fixedPos">重新定位</el-button></el-form-item><el-form-item label="当前纬度"><p>{{latitude}}</p></el-form-item><el-form-item label="当前经度"><p>{{longitude}}</p></el-form-item><el-form-item><div class="f-a-c"><el-input v-model="keyWords" placeholder="请输入地区" style="width: 230px;margin-right: 6px;"></el-input><el-button type="primary" @click="setPlace" :disabled="!keyWords">查询</el-button></div></el-form-item></el-form><div id="map"></div></div><div slot="footer" class="dialog-footer"><el-buttonsize="small"type="primary"v-if="type != '2'"@click="btnSubmit()">确 认</el-button><el-button size="small" @click="popup = false">取 消</el-button></div></el-dialog></div>
</template>

JS代码

<script>export default {name: "mapView",data() {return {map: null,local: null,mk: null,latitude: '',longitude: '',keyWords: ''};},methods: {// 打开弹窗,name为弹窗名称async openDialog(name) {this.text = name;this.popup = true;this.initMap();},// 确认btnSubmit() {let key = {latitude: this.latitude,longitude: this.longitude}// 打印经纬度console.log(key);this.popup = false;},initMap() {this.$nextTick(() => {this.map = new BMap.Map("map");let point = new BMap.Point(116.404, 39.915);this.map.centerAndZoom(point, 12);this.map.enableScrollWheelZoom(true); // 开启鼠标滚轮缩放this.map.addControl(new BMap.NavigationControl());this.fixedPos();});},// 点击定位-定位到当前位置fixedPos() {const _this = this;const geolocation = new BMap.Geolocation();this.confirmLoading = true;geolocation.getCurrentPosition(function (r) {if (this.getStatus() == BMAP_STATUS_SUCCESS) {_this.handleMarker(_this, r.point);let myGeo = new BMap.Geocoder();myGeo.getLocation(new BMap.Point(r.point.lng, r.point.lat),function (result) {_this.confirmLoading = false;if (result) {_this.latitude = result.point.lat;_this.longitude = result.point.lng;}});} else {_this.$message.error("failed" + this.getStatus());}});},// 搜索地址setPlace() {this.local = new BMap.LocalSearch(this.map, {onSearchComplete: this.searchPlace,});this.local.search(this.keyWords);},searchPlace() {if (this.local.getResults() != undefined) {this.map.clearOverlays(); //清除地图上所有覆盖物if (this.local.getResults().getPoi(0)) {let point = this.local.getResults().getPoi(0).point; //获取第一个智能搜索的结果this.map.centerAndZoom(point, 18);this.handleMarker(this, point);console.log("经度:" + point.lng + "--" + "纬度" + point.lat);this.latitude = point.lat;this.longitude = point.lng;} else {this.$message.error("未匹配到地点!");}} else {this.$message.error("未找到搜索结果!");}},// 设置标注handleMarker(obj, point) {let that = this;obj.mk = new BMap.Marker(point);obj.map.addOverlay(obj.mk);obj.mk.enableDragging(); // 可拖拽obj.mk.addEventListener("dragend", function (e) {// 监听标注的拖拽,获取拖拽后的经纬度that.latitude = e.point.lat;that.longitude = e.point.lng;});obj.map.panTo(point);},}};
</script>

CSS代码

<style scoped>.form-layer {width: 100%;}#map {margin-top: 30px;width: 100%;height: 300px;border: 1px solid gray;box-sizing: border-box;overflow: hidden;}/deep/ .el-dialog {min-width: 550px;}/deep/ .el-dialog__body {padding: 10px;}
</style>

完整代码

<template><div><el-dialog@close="clearDialog":close-on-click-modal="false":title="text"style="text-align: left":visible.sync="popup"width="30%"><div class="form-layer"><el-form label-width="100px" size="mini"><el-form-item label="获取定位"><el-button type="primary" @click="fixedPos">重新定位</el-button></el-form-item><el-form-item label="当前纬度"><p>{{latitude}}</p></el-form-item><el-form-item label="当前经度"><p>{{longitude}}</p></el-form-item><el-form-item><div class="f-a-c"><el-input v-model="keyWords" placeholder="请输入地区" style="width: 230px;margin-right: 6px;"></el-input><el-button type="primary" @click="setPlace" :disabled="!keyWords">查询</el-button></div></el-form-item></el-form><div id="map"></div></div><div slot="footer" class="dialog-footer"><el-buttonsize="small"type="primary"v-if="type != '2'"@click="btnSubmit()">确 认</el-button><el-button size="small" @click="popup = false">取 消</el-button></div></el-dialog></div>
</template>
<script>export default {name: "mapView",data() {return {map: null,local: null,mk: null,latitude: '',longitude: '',keyWords: ''};},methods: {// 打开弹窗,name为弹窗名称async openDialog(name) {this.text = name;this.popup = true;this.initMap();},// 确认btnSubmit() {let key = {latitude: this.latitude,longitude: this.longitude}// 打印经纬度console.log(key);this.popup = false;},initMap() {this.$nextTick(() => {this.map = new BMap.Map("map");let point = new BMap.Point(116.404, 39.915);this.map.centerAndZoom(point, 12);this.map.enableScrollWheelZoom(true); // 开启鼠标滚轮缩放this.map.addControl(new BMap.NavigationControl());this.fixedPos();});},// 点击定位-定位到当前位置fixedPos() {const _this = this;const geolocation = new BMap.Geolocation();this.confirmLoading = true;geolocation.getCurrentPosition(function (r) {if (this.getStatus() == BMAP_STATUS_SUCCESS) {_this.handleMarker(_this, r.point);let myGeo = new BMap.Geocoder();myGeo.getLocation(new BMap.Point(r.point.lng, r.point.lat),function (result) {_this.confirmLoading = false;if (result) {_this.latitude = result.point.lat;_this.longitude = result.point.lng;}});} else {_this.$message.error("failed" + this.getStatus());}});},// 搜索地址setPlace() {this.local = new BMap.LocalSearch(this.map, {onSearchComplete: this.searchPlace,});this.local.search(this.keyWords);},searchPlace() {if (this.local.getResults() != undefined) {this.map.clearOverlays(); //清除地图上所有覆盖物if (this.local.getResults().getPoi(0)) {let point = this.local.getResults().getPoi(0).point; //获取第一个智能搜索的结果this.map.centerAndZoom(point, 18);this.handleMarker(this, point);console.log("经度:" + point.lng + "--" + "纬度" + point.lat);this.latitude = point.lat;this.longitude = point.lng;} else {this.$message.error("未匹配到地点!");}} else {this.$message.error("未找到搜索结果!");}},// 设置标注handleMarker(obj, point) {let that = this;obj.mk = new BMap.Marker(point);obj.map.addOverlay(obj.mk);obj.mk.enableDragging(); // 可拖拽obj.mk.addEventListener("dragend", function (e) {// 监听标注的拖拽,获取拖拽后的经纬度that.latitude = e.point.lat;that.longitude = e.point.lng;});obj.map.panTo(point);},}};
</script>
<style scoped>.form-layer {width: 100%;}#map {margin-top: 30px;width: 100%;height: 300px;border: 1px solid gray;box-sizing: border-box;overflow: hidden;}/deep/ .el-dialog {min-width: 550px;}/deep/ .el-dialog__body {padding: 10px;}
</style>

围观地址 vue中调用百度地图 获取经纬度 js获取当前位置经纬度项目中,需要实现获取当前位置的经纬度,或者搜索某个位置并获取经纬度信息,我使用的的是vue,地图使用的是百度地图。默认自动获取当前位置经纬度拖动小红标获取经纬度关键词查询获取经纬度前期准备首先,我们需要取百度官方申请一个地图api秘钥,https://lbsyun....,共享博客http://www.sharedbk.com/post/231.html

诚邀您加入前端五百人技术交流 W/X 群,添加鹏仔 W/X ,备注“前端小哥哥/前端小姐姐”

vue中调用百度地图 获取经纬度相关推荐

  1. vue中调用百度地图实现搜索等功能

    vue中调用百度地图实现搜索等功能 在最近做电商项目时用户订单等物流信息想做的更加详细点所以加入了地图这个小功能,不是很难只是在一个未知的领域可能有点迷茫 现在也是体会到了,学新的东西还是得看官方文档 ...

  2. vue中调用百度地图api

    最近呢,由于工作需要,自己搭一个简单的h5应用给公司的客户,方便预约来访时间,然后写了小半年react-native的我,终于能写web了-(题外话题外话),然后我就欣然拿起久未使用的vue(好吧,还 ...

  3. vue中实现百度地图的引用(根据输入框输入内容获取详细地址)

    vue中实现百度地图的引用(根据输入框输入内容获取详细地址) 代码内容参考:https://www.cnblogs.com/shuaifing/p/8185311.html 最终实现效果 第一步:在i ...

  4. Vue中使用百度地图做路径分析并根据起终点坐标模拟道路里程桩

    1.我们先要在vue中引入百度地图的API 第一步:在vue中的index.html文件中加上一个script标签: <script type="text/javascript&quo ...

  5. Vue中使用百度地图

    安装 npm $ npm install vue-baidu-map --save cdn <script src="https://unpkg.com/vue-baidu-map&q ...

  6. android h5调用百度地图,h5页面如何调用百度地图获取当前位置(代码)

    本篇文章给大家带来的内容是关于h5页面如何调用百度地图获取当前位置(代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 在项目中越来越多的用到了手机的GRS定位功能,使用百度地图A ...

  7. VUE中使用百度地图BaiduMap

    VUE中使用百度地图BaiduMap 以前在html页中使用了echart,做了很多图表,也集成了百度地图,效果很好.最近,开始研究vue加 .net core的框架,所以也想把echart和百度地图 ...

  8. vue使用腾讯地图获取经纬度和逆解析获取详细地址

    vue使用腾讯地图获取经纬度和逆解析获取详细地址 示例 必须在腾讯api中申请自己的key 打开这个webservice用来逆解析详细地址 下面是代码 1 , html创建放地图的容器 <div ...

  9. Vue中使用百度地图——设置地图标注

    知识点:创建Map实例,为指定的位置设置标注 参考博客:https://www.cnblogs.com/liuswi/p/3994757.html 1.效果图:初始化地图,设置指定经纬度为地图中心点坐 ...

最新文章

  1. mysql update w3c_PHP MySQL Update
  2. MYSQL中 ENUM 类型
  3. oracle对象之触发器
  4. MapReduce概述 —— Hadoop权威指南2
  5. MyEclipse字体和保护色设置
  6. c语言程序设计 网上资源,超星尔雅C语言程序设计-资源包完整答案
  7. 下载 保存 sina 微博视频
  8. 如何获取Level2行情接口连接?
  9. fullpage得基本使用
  10. 在线阅读.epub文件的网站
  11. Winlogon通知包(Winlogon Notification Package)
  12. ButterKnife与Fragment的爱恨情仇(java.lang.IllegalStateException: Bindings already cleared.)
  13. echarts渐变进度条
  14. Swoole 使用WSS协议无法正常连接
  15. 微信网页开发——JS-SDK接入以及微信二次分享图标和标题丢失
  16. 妻子抑郁,多次自杀!美国41岁男子爱上AI女友竟挽救了婚姻
  17. Dubbo学习(一):dubbo的基本概念
  18. 外军的现役机载预警雷达(AEW)参数一览表
  19. 【梳理】【失效链接已于2020-09-27替换】(离散数学 第2版 屈婉玲、耿素云、张立昂 高等教育出版社)第19章 初等数论 结论归纳与证明(度盘)
  20. 冲量在线携手中国电信研究院、北京电信和海光信息打造的数信链网的入选2022“星河”隐私计算标杆案例

热门文章

  1. 通达信指标公式编写答疑汇总(二)
  2. Rosalind Java| Computing GC Content
  3. 小福利,带你快速入门sumifs多条件求和函数、设置下拉菜单结合vlookup函数双条件查找数据、excel的切片器(表关联)、数据透视表、数据透视图
  4. 基于控制台的五子棋小游戏(简易)
  5. LeetCode刷题1894-中等-找到需要补充粉笔的学生编号
  6. 一部手机全搞定,抖音发工资了,一共2千多,方法人人可以用
  7. mysql提取身份证生日并查询指定月份的数据
  8. 2010年最新世博攻略
  9. EndNote X9插入参考文献的格式
  10. 编程计算2×3阶矩阵A和3×2阶矩阵B之积C。矩阵相乘的基本方法是:矩阵A的第i行的所有元素同矩阵B第j列的所有元素对应相乘,并把相乘的结果相加,最终得到的值就是矩阵C的第i行第j列的值。