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>
相关推荐
web守墓人1 小时前
【前端】ikun-markdown: 纯js实现markdown到富文本html的转换库
前端·javascript·html
Savior`L1 小时前
CSS知识复习5
前端·css
许白掰1 小时前
Linux入门篇学习——Linux 工具之 make 工具和 makefile 文件
linux·运维·服务器·前端·学习·编辑器
中微子5 小时前
🔥 React Context 面试必考!从源码到实战的完整攻略 | 99%的人都不知道的性能陷阱
前端·react.js
秋田君6 小时前
深入理解JavaScript设计模式之命令模式
javascript·设计模式·命令模式
中微子6 小时前
React 状态管理 源码深度解析
前端·react.js
风吹落叶花飘荡7 小时前
2025 Next.js项目提前编译并在服务器
服务器·开发语言·javascript
加减法原则7 小时前
Vue3 组合式函数:让你的代码复用如丝般顺滑
前端·vue.js
yanlele8 小时前
我用爬虫抓取了 25 年 6 月掘金热门面试文章
前端·javascript·面试
lichenyang4538 小时前
React移动端开发项目优化
前端·react.js·前端框架