Vue-Baidu Map获取选中点的经纬度以及详细地址

小鱼儿心语 :

无论生活怎样,都不要忘记微笑,愿你成为自己的太阳,无需凭借谁的光。

今天给大家分享下在 Vue 项目中使用 Baidu Map 的详细过程?。?!

一、注册百度账号以及密钥(ak)

一、注册百度账号
二、申请成为百度开发者
三、获取服务密钥(ak)
四、使用相关服务功能

大家此时一定有很多疑问,申请(ak)到底要怎么填写呢?

申请(ak)究竟怎么填呢.png

1、应用名称:这个就填写项目的英文简称就可以,这个可以随意一点,例如:我们是主做物流这块的,所以我填的是:“logistics”!
2、应用类型:我本人选择的是 浏览器端,这个具体看你们公司的项目类型把!
3、Referer白名单:格式:*.mysite.com*,*myapp.com* 多个域名之间请用英文半角逗号隔开; 如果呢项目正处在测试阶段的话就设置为英文半角星号* 就可以了?。。?/h6>
二、快速上手

安装


npm install vue-baidu-map --save

使用


  • 全局注册

main.js文件

import Vue from 'vue'
import BaiduMap from 'vue-baidu-map'
Vue.use(BaiduMap, { ak: '你的密钥' })

index.html 文件

该文件如果项目目录中没有的话,也可能在某个文件夹内,一定有哦,耐心找找?。?!

<script type="text/javascript" src="https://api.map.baidu.com/api?v=2.0&ak=你的密钥"></script>
  • 局部注册

如果有按需引入组件的需要,可以选择局部注册百度地图组件,局部注册的 BaiduMap 组件必须声明 ak 属性。 所有的独立组件均存放在 components 文件夹下,按需引用即可。

三、具体实操
<template>
  <el-dialog slot="—" :title="title" :width="width" :visible.sync="showMapComponent" top="5vh" custom-class="baidu-map" @close="cancel">
    <baidu-map
      :style="mapStyle"
      ak="你的密钥"
      :map-click="false"
      :center="center"
      :zoom="zoom"
      :scroll-wheel-zoom="true"
      @click="getClickInfo"
      @moving="syncCenterAndZoom"
      @moveend="syncCenterAndZoom"
      @ready="onBaiduMapReady"
      @zoomend="syncCenterAndZoom"
    >
      <bm-view style="width: 100%; height: 100%;" />
      <bm-marker :position="{lng: center.lng, lat: center.lat}" :dragging="true" animation="BMAP_ANIMATION_BOUNCE" />
      <bm-control :offset="{width: '10px', height: '10px'}">
        <bm-auto-complete v-model="keyword" :sug-style="{zIndex: 999999}">
          <el-input v-model="keyword" type="text" placeholder="请输入地名关键字" clearable>
            <i slot="prefix" class="el-input__icon el-icon-search" />
          </el-input>
        </bm-auto-complete>
      </bm-control>
      <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" show-address-bar auto-location />
      <bm-local-search :keyword="keyword" :auto-viewport="true" :panel="false" />
    </baidu-map>
    <span slot="footer">
      <el-button icon="el-icon-close" @click="cancel">取 消</el-button>
      <el-button icon="el-icon-place" type="primary" @click="confirm">确 定</el-button>
    </span>
  </el-dialog>
</template>

<script>
import { BaiduMap, BmControl, BmView, BmAutoComplete, BmLocalSearch, BmMarker, BmGeolocation } from 'vue-baidu-map'
export default {
  components: {
    BaiduMap,
    BmControl,
    BmView,
    BmAutoComplete,
    BmLocalSearch,
    BmMarker,
    BmGeolocation
  },
  props: {
    // 在子组件中使用 props 选项去接收来自父组件传递过来的数据
    dialogVisible: Boolean,
    mapHeight: {
      type: Number,
      default: 450
    },
    title: {
      type: String,
      default: '选择目标位置'
    },
    width: {
      type: [Number, String],
      default: '85%'
    },
    height: {
      type: [Number, String],
      default: '80%'
    }
  },
  data: function() {
    return {
      BMap: null, // 地图组件是否就绪
      showMapComponent: this.dialogVisible,
      keyword: '', // 地区搜索的信息
      mapStyle: {
        width: '100%',
        height: this.mapHeight + 'px'
      },
      center: { lng: 116.404, lat: 39.915 },
      choosedLocation: { province: '', city: '', district: '', addr: '' },
      zoom: 15
    }
  },
  watch: {
    dialogVisible: function(currentValue) {
      this.showMapComponent = currentValue
      if (currentValue) {
        this.keyword = ''
      }
    }
  },
  methods: {
    // ready事件:在你需要二次开发或手动控制其子组件,可以使用在此事件中使用返回的 BMap 类和 map 实例进行手动控制
    onBaiduMapReady(e) {
      console.log('返回BMap类和map实例', e)
      const that = this
      this.BMap = e.BMap
      if (this.BMap) {
        // 获取定位地址信息并赋值给声明变量
        // Geolocation 对象的 getCurrentPosition()、watchPosition()、clearWatch() 方法详解 :https://blog.csdn.net/zyz00000000/article/details/82774543
        const geolocation = new this.BMap.Geolocation()
        // 通过 getCurrentPosition() 方法:获取当前的位置信息
        geolocation.getCurrentPosition(res => {
          console.log('返回详细地址和经纬度', res)
          const { lng, lat } = res.point
          const { province, city, district, street, street_number } = res.address

          that.center = { lng, lat }
          that.choosedLocation = { province, city, district, addr: street + street_number, lng, lat }
        })
      }
    },

    /** *
     * 地图点击事件。
     */
    getClickInfo(e) {
      // 调整地图中心位置
      this.center.lng = e.point.lng
      this.center.lat = e.point.lat

      // 此时已经可以获取到BMap类
      if (this.BMap) {
        const that = this
        // Geocoder() 类进行地址解析
        // 创建地址解析器的实例
        const geoCoder = new this.BMap.Geocoder()
        // getLocation() 类--利用坐标获取地址的详细信息
        // getPoint() 类--获取位置对应的坐标
        geoCoder.getLocation(e.point, function(res) {
          console.log('获取经纬度', e.point, '获取详细地址', res)
          const addrComponent = res.addressComponents
          const surroundingPois = res.surroundingPois
          const province = addrComponent.province
          const city = addrComponent.city
          const district = addrComponent.district
          let addr = addrComponent.street
          if (surroundingPois.length > 0 && surroundingPois[0].title) {
            if (addr) {
              addr += `-${surroundingPois[0].title}`
            } else {
              addr += `${surroundingPois[0].title}`
            }
          } else {
            addr += addrComponent.streetNumber
          }
          that.choosedLocation = { province, city, district, addr, ...that.center }
        })
      }
    },

    syncCenterAndZoom(e) {
      // 返回地图当前的缩放级别
      this.zoom = e.target.getZoom()
    },
    /** *
     * 确认
     */
    confirm: function() {
      this.showMapComponent = false
      this.$emit('map-confirm', this.choosedLocation)
    },
    /** *
     * 取消
     */
    cancel: function() {
      this.showMapComponent = false
      this.$emit('cancel', this.showMapComponent)
    }
  }
}
</script>

<style lang="scss">
.baidu-map {
  .el-dialog__body {
    padding: 5px !important;
  }
}
</style>

最后效果如下所示:


百度地图示例.png
  • 接下来呢,我给大家详细解析下我所引入得各个组件含义

  • BaiduMap —— 局部注册

  • BmControl —— 允许开发者自由定制控件

  • BmView—— 渲染地图视图
    1、BmView 用于渲染百度地图实例可视化区域的容器,通常与 LocalSearch 等会输出其它视图的组件结合使用;
    2、当 BaiduMap 组件中没有挂载 BmView 组件时,百度地图实例将渲染在 <baidu-map> 节点上;
    3、当 BaiduMap 组件中挂载了 BmView 组件时,百度地图实例将渲染在 <bm-view> 节点上;
    4、每个 BaiduMap 组件应对应唯一一个 BmView 组件,如果声明了多个 BmView 组件,只有第一个能被正常渲染;
    5、该组件主要用于控制布局,除了能够渲染地图视图之外,没有任何其它用途。

  • BmAutoComplete—— 自动填充组件
    1、因为它的定制性较差,如果对检索框没有高级的UI定制需求,就使用这个就好了,将返回的数据配合您自定义的UI组件进行开发;
    2、自动填充组件弹出的检索框有时会被其它层覆盖,此时需要在 sugStyle 属性中声明 zIndex 加以调整。

  • BmLocalSearch—— 地区检索

  • BmMarker—— 自定义覆盖点、标记点

  • BmGeolocation—— 地区定位控件

  • BmNavigation—— 导航控件
  • 接下来呢,我给大家详细解析下我所使用的各个标签、以及标签内的属性的含义

1、标签带el的是 element-UI 插件中的组件
2、标签带bm的是 VUE BAIDU MAP 百度地图中引用的组件
  • <el-dialog></el-dialog>—— 弹出一个对话框
    1、custom-classDialog 的自定义类名;
    2、slot="-" : 表示dialog的内容;
    3、slot="footer" :Dialog 按钮操作区的内容
  • <baidu-map></baidu-map>—— 百度地图容器
    1、用于挂载百度地图核心类和一个百度地图实例,是所有地图组件的根组件;
    2、实质上是一个空的DOM节点,可以用于挂载 BmView 组件或其它DOM节点或组件;
    3、如果你需要二次开发或者是手动控制其子组件,可以使用在 ready 事件中使用返回的 BMap 类和 map 实例进行手动控制,来获取想要的数据;
    4、ready事件:在你需要二次开发或手动控制其子组件,可以使用在此事件中使用返回的 BMap 类和 map 实例进行手动控制;
    5、moving: 地图移动过程中触发此事件;
    6、moveend:地图移动结束时触发此事件;
    7、zoomend:地图更改缩放级别结束时触发此事件;
    8、ak:百度地图开发者平台申请的密钥,仅在局部注册组件时声明;
    9、center:此处我使用对象形式如:{lng:'',lat:''} 表示经纬度,也可以使用如:'太原市万柏林区'的地区字符串;
    10、zoom:表示缩放等级;
    11、scroll-wheel-zoom:允许鼠标滚轮缩放;
    12、map-click:允许点击,该项仅在地图组件挂载时加载一次。
  • <bm-view></bm-view>—— 渲染一个地图实例
    1、当 BaiduMap 挂载了 BmView 组件时,百度地图实例将渲染在 <bm-view> 节点上;
    2、每个 BaiduMap 组件应对应唯一一个 BmView 组件,如果声明了多个 BmView 组件,只有第一个能被正常渲染;
    3、该组件主要用于控制布局。除了能够渲染地图视图以外,没有任何其它用途。
  • <bm-marker></bm-marker>—— 自定义覆盖点:红色点
    1、:dragging="true":允许拖拽;
    2、animation="BMAP_ANIMATION_BOUNCE":反复弹跳;
  • <bm-navigation></bm-navigation>—— 缩放控件
    1、anchor="BMAP_ANCHOR_TOP_RIGHT":控件停靠的位置;
  • <bm-control></bm-control>—— 自定义控件
    1、:offset="{width: '10px', height: '10px'}":控制偏移量;
  • <bm-auto-complete></bm-auto-complete>—— 自动填充组件
    1、因为它的定制性较差,如果对检索框没有高级的UI定制需求,就使用这个就好了,将返回的数据配合您自定义的UI组件进行开发;
    2、弹出的检索框有时会被其它层覆盖,此时需要在 sugStyle 属性中声明 zIndex 加以调整;
  • <bm-geolocation></bm-geolocation>—— 定位组件
    1、anchor-- 控件??课恢?
    2、showAddressBar-- 默认显示定位信息面板;
    3、autoLocation-- 添加控件时是否进行定位,默认不定位;
  • <bm-local-search></bm-local-search>—— 地区检索
    1、keyword-- 搜索关键字;
    2、autoViewport-- 检索结束后是否自动调整地图视野;
    3、panel-- 是否展现检索结果面板;

好了,今天就跟大家分享到这里了,有不懂的或是有技术瑕疵的尽情留言哦,同时也希望能够帮助到刚接触百度地图的宝宝们~~~

?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,172评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,346评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,788评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,299评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,409评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,467评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,476评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,262评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,699评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,994评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,167评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,827评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,499评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,149评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,387评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,028评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,055评论 2 352

推荐阅读更多精彩内容