首页 > 其他分享 >vue3和百度地图关键字检索 定位 点击定位

vue3和百度地图关键字检索 定位 点击定位

时间:2023-01-29 18:44:43浏览次数:62  
标签:定位 const map point value 关键字 BMap vue3 new

效果图

在index.html中引入

百度地图开放平台  去申请你的ak 非常的简单可以自己百度 一下

  <!-- 这个用官网给的有好多警告 更具百度的把 https://api.map.baidu.com/getscript?v=2.0&ak=xxxxxxxxxxxxxxxxxxxxx 换为这个就没有那么多 报错了 -->
  <script
    type="text/javascript"
    src="https://api.map.baidu.com/getscript?v=2.0&ak=xxxxxxxxxxxxxxxxxxxxxxxxxxxxx" // 这个替换为你自己申请的ak 
  ></script>

 创建一个组件

<template>
  <div style="width: 100%; height: 440px;">
    <!-- 显示小地址小框框 -->
    <div class="ipt">
      <div class="address">
        {{ address }}
      </div>
      <!-- 支持模糊查询 -->
      <input type="text" id="suggestId" placeholder="搜索地名" />
    </div>
    <!-- 地图 -->
    <div id="map" :style="{ width: '100%', height: 400 + 'px' }">
    </div>
  </div>
</template>

<script setup lang="ts">
import { onMounted, defineProps, ref, defineEmits } from 'vue'
// 传入的中心点 刷新页面加载的点
const props = defineProps({
  latitude: {
    type: String,
    default: () => {
      return '40.083402'
    },
  },
  longitude: {
    type: String,
    default: () => {
      return '113.368374'
    },
  }
})
// 传出地址
const emits = defineEmits(['addressData'])
// 显示地址
const address = ref('')
// 引入的地图的api
const BMap = (window as any).BMap
onMounted(() => {
  // 创建地图实例
  var map = new BMap.Map('map')
  // 这个创建地理服务的 下面是把定位转换为详细文字地址 
  var geoc = new BMap.Geocoder();
  //建立一个自动完成的对象 主要关键字查询
  var ac = new BMap.Autocomplete(
    {
      // suggestId 是输入框id 
      "input": "suggestId"
      //  这个是地图实例
      , "location": map
    });
  // 下拉列表里的内容确认发生的事件 ()
  ac.addEventListener('onconfirm', function (e: any) {
    // 把城市啥的拼接起来
    const myValue =
      e.item.value.province +
      e.item.value.city +
      e.item.value.district +
      e.item.value.street +
      e.item.value.business
    // 搜索
    // 搜索结束执行的函数
    const mySearchFun = () => {
      // 传入定位函数的经纬度 
      getAddOverlay(local.getResults().getPoi(0).point)
      // 定位中心点 
      map.centerAndZoom(local.getResults().getPoi(0).point, 15)
    }
    // 创建一个搜索的实例
    var local = new BMap.LocalSearch(map, {
      //搜索成功后的回调 
      onSearchComplete: mySearchFun,
    })
    // 传入搜索位置的关键字
    local.search(myValue)
  })

  // 下面是开始定位的
  var point = new BMap.Point(props.longitude, props.latitude) // 定位
  getAddOverlay(point)
  map.centerAndZoom(point, 5) // 中心点位 15是级别
  map.enableScrollWheelZoom(true);     //开启鼠标滚轮缩放
  // 当地图点击的时候发生的事件 
  map.addEventListener('click', function (e: any) {
    // 创建标点
    getAddOverlay(new BMap.Point(e.point.lng, e.point.lat))
  })
  // 定位点的函数  
  function getAddOverlay(point: any) {
    // 清空地图上所有的标准当然你想要多个点的话可以不清除
    map.clearOverlays()
    var marker = new BMap.Marker(point);        // 创建标注    
    map.addOverlay(marker); // 添加到地图
    // 把定位转换为详细文字地址  
    geoc.getLocation(point, (rs: any) => {
      // 显示到页面上
      address.value = rs.address
    })
    // 把位置传出
    emits('addressData', point)
  }
})

</script>


<style lang="scss" >
.anchorBL {
  display: none;
}
</style>
<style lang="scss"  scoped>
.ipt {
  position: relative;
  display: flex;
  justify-content: flex-end;
  width: 100%;
  min-width: 300px;
  height: 25px;
  margin-bottom: 10px;

  #suggestId {
    width: 40%;
    min-width: 250px;
    padding: 5px 10px;
    outline: none;
    font-size: 13px;
    font-family: monospace;
    color: #606266;
    border-radius: 4px;
    border: 1px solid #ddd;
  }

  .address {
    position: absolute;
    width: 300px;
    height: 20px;
    font-size: 12px;
    left: 0;
    bottom: 0;
  }
}
</style>

 

在父组件引入

  <center-map @addressData="addressData" :latitude="latitude" :longitude="longitude"></center-map>

  

标签:定位,const,map,point,value,关键字,BMap,vue3,new
From: https://www.cnblogs.com/qiaomucreate/p/17073571.html

相关文章

  • 搞定物联网定位:UWB高精度定位技术原理与实现
    搞定物联网定位:UWB高精度定位技术原理与实现https://mp.weixin.qq.com/s/18kCIFtKCfSQGoZy4NDLaA搞定物联网定位:UWB高精度定位技术原理与实现原创 刘恒进 腾讯云开发......
  • GFast V3.2.1 版本发布,采用 GoFrame 2.3 + Vue3 后台管理系统
    平台简介基于全新GoFrame2.3+Vue3+ElementPlus开发的全栈前后端分离的管理系统前端采用vue-next-admin、Vue、ElementUI。特征高生产率:几分钟即可搭建一个后台管......
  • vue3+betterScroll scroll滚动组件
    betterScroll在MVVM框架中使用时最麻烦的是更新时机,一般的需要滚动的列表数据都是来源于后端,是异步的。就必须要渲染完后refresh()一下。但是单独的Scroll组件是通过插槽放......
  • 黑马程序员前端-HTML+CSS之定位(position)的应用
     前端学习笔记教程不定期更新中,传送门:​​前端HTML第一天:什么是网页?什么是HTML?网页怎么形成?​​​​黑马程序员前端-CSS入门总结​​​​黑马程序员前端-CSS之emmet语法​......
  • Vue3用vue ui创建vue2项目时报错
    问题:选中以Vue2默认模板创建时候,下方和控制台出现以下报错Failedtogetresponsefromhttps://registry.yarnpkg.com/vue-cli-version-marker解决:查看C盘下的.vuerc......
  • 浅谈synchronized关键字的理解
    简介:synchronized关键字解决的是多个线程之间访问资源的同步性,synchronized关键字可以保证被它修饰的方法或者代码块在任意时刻只能有一个线程执行。synchronized属于独占......
  • 定位的div环形圆形排列
    要实现一个类似于下图的效果,十个标签从中间随机出现的动画效果,若没有十个则按定义位置出现1.将十个标签都固定在中心位置,通过class,并且动态生成标签颜色<div......
  • vscode 利用正则 搜索标签 tags (?=.*关键字1)(?=.*关键字2).*
    vscode利用正则搜索标签(?=.关键字1)(?=.关键字2).*这里关键词是可以多个并且不按照顺序搜索的,就是写起来需要(?=.关键字)最后.结尾我是不是需要制作一个转换的小......
  • Vue3数据对接报错(Unhandled error during execution of render function )
    如图:、 意思就是说:多了个value,在渲染div的时候,一些部分不应该有value查看一下传输数据的时候中间是否有null值的,或者无效值 ......
  • 感受Vue3的魔法力量
    作者:京东科技牛至伟近半年有幸参与了一个创新项目,由于没有任何历史包袱,所以选择了Vue3技术栈,总体来说感受如下:•setup语法糖<scriptsetuplang="ts">摆脱了书写声明式的......