Vue项目使用百度地图展示或搜索地点(vue-baidu-map)

Vue项目使用百度地图展示或搜索地点(vue-baidu-map)

  1. 安装插件:yarn add vue-baidu-map

  2. main.js全局中引入:

    import BaiduMap from 'vue-baidu-map'
    Vue.use(BaiduMap, {
      ak: 'your_app_key' // 百度地图秘钥
    })
    
  3. 使用
    3.1 在地图上展示标注地点
    百度地图坐标拾取工具

    <div class="m-map-container">
        <div class="m-map">
            <baidu-map
                class="bmView"
                :scroll-wheel-zoom="false" // 禁止鼠标滚轮缩放
    			:dragging="false" // 禁止拖拽
    			:double-click-zoom="false" // 禁止鼠标双击缩放
                :map-click="false" // 禁用鼠标点击查看详情
                :center="location"
                :zoom="zoom">
                <bm-marker :position="location" animation="BMAP_ANIMATION_BOUNCE"></bm-marker>
                <bm-view style="width: 100%; height: 480px; flex: 1;border-radius: 5px;"></bm-view>
            </baidu-map>
        </div>
    </div>
    data () {
        return {
            location: {
                lng: 102.68906,
                lat: 25.049784
            }, // 指定地点的经纬度
            zoom: 20 // 地图缩放比例
        }
    }
    .m-map-container {
      width: 1200px;
      text-align: center;
      margin: 0 auto;
      background: #fff;
      .m-map {
        margin: 0 auto;
        width: 800px;
        padding-top: 60px;
      }
    }
    // 移除左下角百度地图版权
    /deep/ div.BMap_cpyCtrl.BMap_noprint.anchorBL {
      display: none;
    }
    // 移除左下角百度地图logo
    /deep/ div.anchorBL {
      display: none;
    }
    // 悬浮地图时不展示小手
    /deep/ .BMap_mask {
      cursor: default;
    }
    

    3.2 在地图上搜索地点,并可通过鼠标点击获取其经纬度及详细地址信息

    <template>
      <a-modal
        title="地址坐标"
        :width="980"
        :visible="visible"
        :confirmLoading="confirmLoading"
        @cancel="handleCancel"
        :footer="null"
      >
        <a-spin :spinning="confirmLoading">
          <a-form :form="form">
            <a-row :gutter="16">
              <a-col :lg="12" :md="12">
                <a-form-item>
                  <a-input-search
                    placeholder="请输入地址"
                    enter-button="查询"
                    @search="handleSearch"
                    v-decorator="['address',{initialValue: defaultAddress}]"
                  />
                </a-form-item>
              </a-col>
              <a-col :lg="12" :md="12">
                <a-form-item label="坐标" :labelCol="labelCol" :wrapper-col="wrapperCol">
                  <a-input
                    v-decorator="['address_coordinates']"/>
                </a-form-item>
              </a-col>
            </a-row>
            <div class="map">
              <!-- 地图点击事件getLocationPoint,获取地点详细信息、经纬度 -->
              <!-- scroll-wheel-zoom:是否可以用鼠标滚轮控制地图缩放,zoom:视图比例 -->
              <!-- dragging:是否可以用鼠标进行拖拽 -->
              <!-- double-click-zoom:是否可以用鼠标双击控制地图缩放 -->
              <!-- map-click:是否可以用鼠标点击查看详情 -->
              <baidu-map
                class="bmView"
                :scroll-wheel-zoom="true"
                :zoom="zoom"
                @click="getLocationPoint"
              >
                <!-- 右上角比例尺控件 -->
                <bm-scale anchor="BMAP_ANCHOR_TOP_RIGHT"></bm-scale>
                <!-- 右上角缩放控件 -->
                <bm-navigation anchor="BMAP_ANCHOR_TOP_RIGHT"></bm-navigation>
                <!-- 左上角地图类型控件 -->
                <bm-map-type :map-types="['BMAP_NORMAL_MAP', 'BMAP_HYBRID_MAP']" anchor="BMAP_ANCHOR_TOP_LEFT"></bm-map-type>
                <!-- 右下角缩略图 -->
                <bm-overview-map anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :isOpen="true"></bm-overview-map>
                <!-- 右下角加入定位控件 -->
                <bm-geolocation anchor="BMAP_ANCHOR_BOTTOM_RIGHT" :showAddressBar="true" :autoLocation="true"></bm-geolocation>
                <!-- 左上角加入城市列表 -->
                <bm-city-list anchor="BMAP_ANCHOR_TOP_LEFT"></bm-city-list>
                <!-- 右上角加入全景控件 -->
                <!-- <bm-panorama anchor="BMAP_ANCHOR_BOTTOM_LEFT"></bm-panorama> -->
                <bm-view class="u-bm-view"></bm-view>
                <bm-local-search :keyword="addressKeyword" :auto-viewport="true" class="u-search"></bm-local-search>
              </baidu-map>
            </div>
            <span class="m-span">
              <a-form-item style="margin-top: 20px;margin-bottom: 10px;">
                <a-button class="u-submit" type="primary" htmlType="submit" @click="handleSubmit">确定</a-button>
                <a-button class="u-cancal" @click="handleCancel">取消</a-button>
              </a-form-item>
            </span>
          </a-form>
        </a-spin>
      </a-modal>
    </template>
    <script>
    export default {
      data () {
        return {
          labelCol: {
            lg: { span: 4 },
            md: { span: 4 }
          },
          wrapperCol: {
            lg: { span: 20 },
            md: { span: 20 }
          },
          form: this.$form.createForm(this),
          addParams: {
            mod: 'add'
          },
          defaultAddress: '',
          visible: false,
          confirmLoading: false,
          zoom: 12,
          addressKeyword: ''
        }
      },
      methods: {
        getLocationPoint (e) {
          console.log('e:', e)
          console.log(e.point.lng + ',' + e.point.lat)
          /*
    	    可以通过在.eslintrc.js中加入:
    	    globals: {
    	        BMap: true
    	    }, // 防止eslint报错:'BMap' is not defined.
    	    或者直接使用:// eslint-disable-next-line no-undef
          */
          const geoCoder = new BMap.Geocoder() // 创建地址解析器的实例
          /* 利用坐标获取地址的详细信息 */
          geoCoder.getLocation(e.point, res => {
            console.log('res:', res)
            this.form.setFieldsValue({
              // 地址和经纬度
              address: res.address,
              address_coordinates: res.point.lng + ',' + res.point.lat
            })
          })
        },
        handleSearch (value) {
          console.log(value)
          this.addressKeyword = value
        },
        check (value) {
          if (!this.defaultAddress) {
            this.defaultAddress = value
          } else {
            this.form.setFieldsValue({
              address: value
            })
          }
          this.addressKeyword = value
          this.visible = true
        },
        handleSubmit (e) {
          e.preventDefault()
          const { form: { validateFields } } = this
          this.confirmLoading = true
          validateFields((errors, values) => {
            if (!errors) {
              this.visible = false
              this.confirmLoading = false
              console.log('values:', values)
              this.$emit('ok', values)
            } else {
              this.confirmLoading = false
            }
          })
        },
        handleCancel () {
          this.visible = false
        }
      }
    }
    </script>
    <style lang="less" scoped>
    // 移除左下角百度地图版权
    /deep/ div.BMap_cpyCtrl.BMap_noprint.anchorBL{
      display: none;
    }
    // 移除左下角百度地图logo
    /deep/ div.anchorBL{
      display: none;
    }
    .u-bm-view{
       width: 100%;
       height: 500px;
       flex: 1;
    }
    .m-span{
      text-align: center;
    }
    .u-submit{
      margin-right: 30px;
      width: 100px;
    }
    .u-cancal{
      margin-left: 30px;
      width: 100px;
    }
    /deep/ .BMap_CityListCtrl{
      margin-top: 30px;
      div div {
        .city_content_top{
          height: 36px;
          .cur_city_info{
            position: absolute;
            bottom: 0px;
            height: 24px;
          }
          #city_ctrl_form{
            .sel_city_input{
              height: 24px;
            }
          }
        }
      }
    }
    .u-search{
      display:none;
    }
    </style>
    

原文连接:https://blog.csdn.net/Dandrose/article/details/112623864

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: vue-baidu-map是基于百度地图API开发的Vue组件,它能够在Vue项目中轻松地集成百度地图。而离线百度地图是指在没有网络连接的情况下能够使用百度地图。 正常情况下,百度地图需要联网才能显示地图和获取相关数据。但是在有些场景下,比如地下车库或者偏远山区等网络较差或者没有网络的地方,就无法正常使用百度地图。离线百度地图就是解决这个问题的解决方案,它通过事先将地图数据下载保存在本地,使得在没有网络连接的情况下也能够正常使用百度地图。 对于vue-baidu-map来说,它的离线功能也是很重要的。通过使用vue-baidu-map的离线百度地图,开发者可以轻松地针对不同的场景选择不同的地图方案,提高用户的使用体验。而且离线百度地图对于一些隐私性、安全性要求高的应用场景也更加有优势。 总之,vue-baidu-map离线百度地图是一个非常实用与方便的工具,在实际生产中可以提供更好的用户体验,也为开发者提供了更多的选择与便捷。 ### 回答2: vue-baidu-map离线百度地图是一款基于Vue.js框架开发的百度地图组件库,主要解决的是在无网络或网络不稳定的情况下,无法使用在线地图的问题。该组件库提供的离线地图可以在无网络的情况下正常使用,并且具有与在线地图相同的功能和可视化效果。 在vue-baidu-map离线百度地图组件中,我们可以使用百度地图提供的基础地图、卫星地图、混合地图等多种地图样式,并且支持地名搜索、地图缩放、位置探测、路线规划等常用功能。此外,在使用vue-baidu-map离线百度地图时,我们也可以通过添加自定义数据层、自定义覆盖层等方式,对地图进行更加丰富的扩展和定制。 总之,vue-baidu-map离线百度地图是一款非常实用的地图组件库,它可以帮助我们在网络不稳定或者无网络的情况下,依然可以正常使用百度地图,并且具有完整的百度地图功能和美观的地图样式。如果你正在建设一个应用程序,需要集成离线地图功能,那么vue-baidu-map离线百度地图可能正是你需要的工具。 ### 回答3: vue-baidu-map是一个可嵌入Vue.js网站的地图组件,它集成了百度地图的API,可以让开发者轻松实现地图功能。 离线百度地图指的是一种不需要联网即可使用百度地图,也就是地图数据被下载到本地储存设备上。vue-baidu-map支持使用离线地图,这就意味着用户可以在没有网络的环境下依然能够使用地图功能。 使用vue-baidu-map离线百度地图的优势在于,它提供了更好的用户体验和更高的灵活性。首先,用户无需担心网络不稳定、信号弱的问题,可以随时随地使用地图进行定位、浏览、搜索等操作;其次,开发者可以根据具体需求选择下载特定区域的地图数据,以减少数据流量和缩短加载时间;还可以根据不同需求切换在线地图和离线地图,达到最佳的用户体验。 总之,vue-baidu-map离线百度地图为开发者提供了便捷灵活的地图开发工具,让用户可以更加自由地使用地图服务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值