Vue3引入腾讯地图,点击坐标后实时获取经纬度

本文将介绍如何在Vue 引入腾讯地图组件,引入后可以直接在页面中渲染腾讯地图,实现 经纬度 与 地图锚点位置的双向绑定,如:

  • 1,输入经纬度后,地图自动定位到指定位置;
  • 2,鼠标在地图点击后,自动获取到地址的经纬度;

最终实现效果如下:

实现细节

1,引入腾讯地图,需要借助腾讯地图提供的 SDK,先需要在腾讯地图开发平台添加应用,申请对应的调用 key凭证,开发平台地址:https://lbs.qq.com/dev/console/application/mine

2,找到Vue/Vue3 项目中的 index.html , 通过 script 标签 引入 腾讯地图 sdk

html 复制代码
  <script charset="utf-8" src="https://map.qq.com/api/gljs?v=1.exp&key=你的Key"></script>

3,在组件中实现核心代码,渲染地图组件,

  • 监听地图点击事件,实时获取点击地点对应的经纬度;
  • 监听文本框输入经纬度值,在地图中渲染目标地点;
vue 复制代码
<template>
  <div style="display: flex; justify-content: center; flex-direction: column; align-items: center; padding: 300px;">
    <div>
      <a-form>
        <div style="display: flex;justify-content: flex-start;">
          <a-form-item label="纬度">
            <a-input v-model:value="loc.lat"></a-input>
          </a-form-item>
          <a-form-item label="经度">
            <a-input v-model:value="loc.lng"></a-input>
          </a-form-item>
        </div>
      </a-form>
    </div>
    <div class="common-map-loc">
      <div id="container">
      </div>
    </div>
  </div>
</template>
<script setup>
import { ref, onMounted, watch } from 'vue'
let loc = ref({
  lat: 39.984104,
  lng: 116.307503,
  address: ''
})
watch(() => loc.value.lat,
  (val, o) => {
    console.log('val is ', val)
    flushLatLon()
  }
)

watch(() => loc.value.lng,
  (val, o) => {
    console.log('val is ', val)
    flushLatLon()
  }
)

// 刷新地图
function flushLatLon() {
  var element = document.getElementById("container");
  while (element.firstChild) {
    element.removeChild(element.firstChild);
  }

  var center = new TMap.LatLng(loc.value.lat, loc.value.lng);//设置中心点坐标
  //初始化重新定位
  var map = new TMap.Map("container", {
    center: center
  });
}
// 组件挂载后,渲染对应组件
onMounted(() => {
  var center = new TMap.LatLng(loc.value.lat, loc.value.lng);//设置中心点坐标
  //初始化地图
  var map = new TMap.Map("container", {
    center: center
  });

  //绑定点击事件
  map.on("click", function (evt) {
    console.log('event is ', evt)
    var lat = evt.latLng.getLat().toFixed(6);
    var lng = evt.latLng.getLng().toFixed(6);
    loc.value.lat = lat
    loc.value.lng = lng
  })
})

</script>

<style scoped lang="less">
.common-map-loc {
  position: relative;

  #ccontainer {
    width: 100%;
    height: 100%;
  }

  #info {
    position: absolute;
    left: 20px;
    top: 20px;
    font-size: 14px;
    background: #FFF;
    width: 40%;
    padding: 10px;
    border-radius: 3px;
  }
}

.search-div {
  display: flex;
  justify-content: center;
}
</style>
相关推荐
xiaoqi9229 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
打小就很皮...9 小时前
Tesseract.js OCR 中文识别
前端·react.js·ocr
qq_177767379 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462109 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n9 小时前
JavaScript内存管理与执行上下文
前端·javascript
Hi_kenyon10 小时前
理解vue中的ref
前端·javascript·vue.js
jin12332210 小时前
基于React Native鸿蒙跨平台地址管理是许多电商、外卖、物流等应用的重要功能模块,实现了地址的添加、编辑、删除和设置默认等功能
javascript·react native·react.js·ecmascript·harmonyos
2501_9209317011 小时前
React Native鸿蒙跨平台医疗健康类的血压记录,包括收缩压、舒张压、心率、日期、时间、备注和状态
javascript·react native·react.js·ecmascript·harmonyos
落霞的思绪11 小时前
配置React和React-dom为CDN引入
前端·react.js·前端框架
Hacker_Z&Q11 小时前
CSS 笔记2 (属性)
前端·css·笔记