vue 集成腾讯地图基础api Demo集合

本文介绍了如何在Vue项目中集成腾讯地图API,包括基础地图展示、3D/2D切换、位置服务和标记功能。同时,详细讲解了如何解决位置逆解析服务的跨域问题和授权问题,提供了配置跨域的代码示例,并提醒读者注意注册并正确设置腾讯地图的开发者key。
摘要由CSDN通过智能技术生成

vue 集成腾讯地图基础api Demo集合(基础地图引入与展示模块,地址逆解析,3D/2D切换 ,位置服务,mark标记)

写作背景

官方网站的demo大部分都是原生js,较基础,很多高级Api分布比较分散,为了有利于开发者查找,使用vue结合网上的开源框架vue-admin参照官方网站demo,做一个开箱即用的Demo集合出来。( down下项目来会有个登录界面,随便输入六个字符就可以了)

项目预览

在这里插入图片描述大家可以从这个地址直接拉取代码 然后复制粘贴就好了。

项目说明

由于笔者时间仓促,目前只整理了四个模块分别是(如果效果不错将继续更新,欢迎各位道友提issues,看到会及时解决):

  1. 基础地图引入与展示模块
  2. 3D/2D切换 与效果对比
  3. 关于位置服务的一些基础api 依次为:定位当前位置,定位到初始化位置,定位中心点,添加鼠标点击事件,切换隐藏与显示地图文字
  4. mark标记的基础使用,依次为:添加标记,结束添加标记事件,mark标记点可拖拽。

前期准备工作

点击这条连接注册腾讯地图开发者账号

注意点

这是一个Vue集成腾讯地图的demo
项目中需要在index.html上事先引入以下内容

 <script src="https://map.qq.com/api/gljs?v=1.exp&key=你注册之后获取的key值"></script>
 <script src="https://mapapi.qq.com/web/mapComponents/geoLocation/v/geolocation.min.js"></script>
 <script charset="utf-8" src="https://map.qq.com/api/gljs?libraries=tools&v=1.exp&key=你注册之后获取的key值"></script>

然后在main.js 文件下写入这几行代码

Vue.prototype.$Map = window.TMap
Vue.prototype.$Location = new window.qq.maps.Geolocation('你自己的key', '腾讯地图模板-博客展示')

书到此地,大部分道友应该直接复制粘贴就可以完美的跑起腾讯地图了。

更新:如何加入位置逆解析服务

调用此服务必须拥有开发者账号并申请属于自己的key,点击这条连接注册腾讯地图开发者账号,获取key。
具体使用方法:
通过get方法调用 :

{
rul:'http://localhost:9528/qq/ws/geocoder/v1/?location=lat,lng&key=你的key&get_poi=1'}

位置逆解析有几处注意的地方:

  1. 跨域
    不知道是不是只有自己这样,在本地启动项目时调用逆解析地址会报跨域问题,需要各位在程序里配置好跨域代码如下
    在vue.config.js里面配置跨域(如果是cli低版本的朋友,麻烦自行网上搜索解决方案,已经比较健全了,笔者就不在这里赘述)
devServer: {
    port: port,
    open: true,
    overlay: {
      warnings: false,
      errors: true
    },
    proxy: { // 配置跨域
      '/qq': {
        target: 'https://apis.map.qq.com/', // 这里后台的地址模拟的;应该填写你们真实的后台接口
        ws: true,
        changOrigin: true, // 允许跨域
        pathRewrite: {
          '^/qq': '' // 请求的时候使用这个api就可以
        }}
    },

  1. 授权报错
    报错类型如下
 	{
    "status": 110,
    "message": "请求来源未被授权, 此次请求来源域名:localhost9528"
	}

 	{
    "status": 112,
    "message": "IP未被授权,当前IP:127.0.0.1"
	}

 {
    "status": 111,
    "message": "签名验证失败"
  }

解决方法均是通过腾讯位置服务平台,结合官方文档配置key管理,如图
在这里插入图片描述详细api参数请参照 官方文档

原文作者:咱们得站着 原文链接:https://blog.csdn.net/xiaoyaoluntian/article/details/112572353

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信小程序是一种通过微信平台开发的应用程序,可以在微信环境中直接运行。腾讯地图腾讯公司开发的地图服务平台,提供了丰富的地图展示和定位功能。 要将腾讯地图接入到微信小程序的Vue项目中,需要进行以下几个步骤: 1. 在Vue项目中安装并引入腾讯地图SDK。可以使用npm或yarn等包管理工具,在项目的根目录下运行以下命令安装: ``` npm install @tencent/txv-map --save ``` 2. 在小程序的配置文件(app.json)中添加使用腾讯地图的权限设置: ``` "permission": { "scope.userLocation": { "desc": "你的位置信息将用于地图定位功能" } } ``` 3. 在Vue组件中引入并使用腾讯地图SDK,可以在需要显示地图的地方插入以下代码: ```vue <template> <view> <map id="map" longitude="113.324520" latitude="23.099994" bindmarkertap="markertap" style="width: 100%; height: 300rpx;" show-location enable-rotate ></map> </view> </template> <script> import { createFrom } from '@tencent/txv-map' export default { methods: { markertap() { console.log('marker tap') } }, created() { // 初始化地图 createFrom({ id: 'map', longitude: 113.324520, latitude: 23.099994 }) } } </script> ``` 以上代码中,我们使用了`<map>`标签来展示地图,并通过`createFrom`方法初始化了地图,并设定了地图的初始经纬度。 4. 在微信小程序的开发者后台中,注册并申请使用腾讯地图的开发者账号,并获取到开发者密钥(key)。在Vue项目中的地图初始化代码中,将开发者密钥替换为你申请到的密钥。 通过以上步骤,你就可以在微信小程序的Vue项目中成功接入腾讯地图,并实现地图的展示和定位功能了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值