uniapp获取当前位置保姆级教程(uni.getFuzzyLocation和腾讯地图API)

简介: uniapp获取当前位置保姆级教程

实现截图



编译器:Hbuilder,运行器:微信开发者工具


主要流程:在微信开发者官网申请uni.getFuzzyLocatoin权限=>利用该方法调用出当前位置经纬度=>在腾讯地图开发官网中注册并创建应用获取密钥=>利用腾讯地图API对前者的经纬度进行转义实现获取当前位置**

下面就是全套教程


前期准备工作


在开始前,需要在微信开发者平台申请uni.getFuzzyLocation API的权限,如何申请getFuzzyLocation在我的另一篇文章有讲到,链接放在下面.这里就不赘述了

https://blog.csdn.net/lplovewjm/article/details/130215474?spm=1001.2014.3001.5501


还需要在腾讯地图开发者官网注册账号官网链接放在下面

https://lbs.qq.com/


一、如何使用getFuzzyLocation接口获取经纬度


我先默认你已经在微信开发者官网申请授权getFuzzyLocation,


使用流程:配置manifest.json=>配置page.json=>页面调用方法以及实现.


配置manifest.json


创建完uniapp项目后点击marnfest.json在它左侧视图中找到源码视图并点击.



加上如下代码:


appid设置成自己的Id


/* 小程序特有相关 */
      "mp-weixin" : {
          "appid" : "wxa8e6388009466d0c",
          "setting" : {
              "urlCheck" : false
          },
          "usingComponents" : true,
          "permission" : {
              "scope.userFuzzyLocation":{
                "desc":"位置信息效果展示"
              }
          },
          "requiredPrivateInfos" : [ "getFuzzyLocation" ]
      },



配置完点击pages.json


"permission":{
  "scope.userFuzzyLocation":{
    "desc":"位置信息效果展示"
  }
}




配置完后点击要运行的页面调用接口

<template>
</template>
<script>
  export default {
    data() {
      return {
        longitude: null,
        latitude: null,
      }
    },
    onLoad() {
      this.location()
    },
    methods: {
      location() {
        var that=this
        uni.getFuzzyLocation({
          success: function(res) {
            this.longitude=res.longitude
            this.latitude=res.latitude
            console.log(res)
          },
        });
      }
    }
  }
</script>
<style>
  .title {
    display: inline-block;
    margin: 20px;
    font-size: 20px;
  }
</style>


运行该代码即可成功调用uni.getFuzzyLocation接口,并获取到经纬度,


二、如果调用腾讯地图API来根据经纬度输出所在位置


注册腾讯地图开发者=>点击左上角控制台=>点击管理应用-我的应用=>在右上角找到创建应用=>创建应用的key=>在页面中调用方法.



1.注册腾讯地图开发者


官网:https://lbs.qq.com/


注册成功后点击右上角控制台:




在左侧工具栏中点击管理应用-我得应用



点击右上角创建应用,配置应用信息


创建成功后点击添加key:



配置成功后返回运行界面,调用腾讯地图API并且显示数据.


全部代码如下:


腾讯地图中的key要用自己的key


<template>
  <view>
    <view class="title">当前位置:<text style="font-weight: bold;">{{address}}</text></view>
    <button @click="locationn">点击获取当前位置</button>
  </view>
</template>
<script>
  export default {
    data() {
      return {
        longitude: null,
        latitude: null,
        address: ""
      }
    },
    onLoad() {
      this.location()
    },
    methods: {
      location() {
        var that=this
        uni.getFuzzyLocation({
          success: function(res) {
            that.longitude=res.longitude
            that.latitude=res.latitude
          },
        });
      },
      locationn() {
        console.log(this.longitude)
        console.log(this.latitude)
        uni.request({
          url: `https://apis.map.qq.com/ws/geocoder/v1/?location=${encodeURIComponent(this.latitude)},${encodeURIComponent(this.longitude)}&key=E7XBZ-FUXC7-D22XZ-POFT7-OD5LJ-6RBAV&get_poi=1`,
          method: 'GET',
          success: (res) => {
            console.log(res)
            this.address=res.data.result.ad_info.city
          }
        })
      }
    }
  }
</script>
<style>
  .title {
    display: inline-block;
    margin: 20px;
    font-size: 20px;
  }
</style>


2.代码逻辑


利用onLoad生命周期函数来调用getFuzzyLocation方法获取经纬度,把经纬度赋给data的数据中,点击调用腾讯地图API,把我想要的值赋给


address,在template中进行显示.


注:腾讯地图API中的url中的是`而不是’,


that调用也可以替换成success:()=>{}方式,本质上都是指向



总结


在本文中介绍了getFuzzyLocation的简单使用和腾讯地图API的简单调用,它俩的用法还有很多,包括微信开发者工具自带的getLocation就可以实现上述效果,但是申请没有getFuzzyLocation好申请,腾讯地图API中也可以根据当前IP地址来进行调用,在官网中都有详细的接口文档供大家使用,文章对于我而言最难的部分其实是腾讯地图的API调用,因为老是显示location格式不正确,所以一直以为是url的接口写错了,最后才发现原来是success没有用=>,把this改成var that= this 调用that就解决了,

最后,文章有点长,希望能帮到大家.


进窄门,走远路,见微光.



相关文章
|
7天前
|
API
车牌号归属地查询免费API接口教程
本接口用于根据车牌号查询社会车辆的归属地,不支持军车、使馆等特殊车牌。请求地址为 `https://cn.apihz.cn/api/other/chepai.php`,支持 POST 和 GET 请求。请求参数包括 `id`、`key` 和 `words`,返回数据包含车牌归属地信息。示例请求:`https://cn.apihz.cn/api/other/chepai.php?id=88888888&key=88888888&words=川B1234`。
41 21
|
6天前
|
API
获取网页重定向地址免费API接口教程
该API用于获取网页重定向跳转后的最终地址。请求地址为`https://cn.apihz.cn/api/wangzhan/tiaozhuan.php`,支持POST或GET方式。请求参数包括`id`、`key`和`url`,返回数据包含状态码`code`和最终URL`url`。示例返回:`{&quot;code&quot;:200,&quot;url&quot;:&quot;https://www.baidu.com/&quot;}`。
47 29
|
10天前
|
API
将秒数转换为时间免费API接口教程
该API用于将指定秒数转换为年、日、时、分、秒。支持指定转换类型。请求地址为 `https://cn.apihz.cn/api/time/stime.php`,需提供ID、密钥、类型和秒数参数。返回结果包含转换后的年、日、时、分、秒等信息。示例请求:`https://cn.apihz.cn/api/time/stime.php?id=88888888&key=88888888&type=1&s=123456`。更多详情见 [文档](https://www.apihz.cn/api/timestime.html)。
将秒数转换为时间免费API接口教程
|
7天前
|
网络协议 API
检测指定TCP端口开放状态免费API接口教程
该API用于检测目标主机指定TCP端口是否开放,适用于检测连通状态等场景。支持指定大陆、美国、香港等检测节点。请求地址为 `https://cn.apihz.cn/api/wangzhan/port.php`,支持POST和GET请求方式。请求参数包括 `id`、`key`、`type`、`host` 和 `port`。返回参数包含检测结果和状态码。示例请求:`https://cn.apihz.cn/api/wangzhan/port.php?id=88888888&key=88888888&type=1&host=49.234.56.78&port=80`。
|
5天前
|
API 数据安全/隐私保护
抖音视频,图集无水印直链解析免费API接口教程
该接口用于解析抖音视频和图集的无水印直链地址。请求地址为 `https://cn.apihz.cn/api/fun/douyin.php`,支持POST或GET请求。请求参数包括用户ID、用户KEY和视频或图集地址。返回参数包括状态码、信息提示、作者昵称、标题、视频地址、封面、图集和类型。示例请求和返回数据详见文档。
|
10天前
|
API
图片压缩+格式转换免费API接口教程
这是一个免费的图片压缩和格式转换API接口,支持GET和POST请求。请求地址为 `https://cn.apihz.cn/api/img/yasuo.php`,需提供 `id`、`key`、`img` 等参数。返回数据包含处理后的图片URL和其他相关信息。更多详情请参考:https://www.apihz.cn/api/imgyasuo.html
|
10天前
|
API
天气预报-腾讯天气-7天-IP查询版免费API接口教程
根据IP地址自动查询该IP归属地7天天气预报的腾讯天气API。请求地址为`https://cn.apihz.cn/api/tianqi/tengxunip.php`,支持GET和POST请求。需提供ID、Key和IP地址作为参数。返回数据包含天气预报信息。
|
9天前
|
前端开发 JavaScript API
取网页纯文本内容免费API接口教程
该API用于获取指定网页的纯文本内容,去除HTML标签、CSS和JS等元素。支持POST和GET请求,需提供ID、Key、URL等参数。请求示例:https://cn.apihz.cn/api/wangzhan/getyuan.php?id=88888888&key=88888888&url=www.apihz.cn&dy=1。返回纯文本数据。
|
1月前
|
API 微服务
Traefik 微服务 API 网关教程(全)
Traefik 微服务 API 网关教程(全)
|
2月前
|
存储 JSON API
实战派教程!Python Web开发中RESTful API的设计哲学与实现技巧,一网打尽!
在数字化时代,Web API成为连接前后端及构建复杂应用的关键。RESTful API因简洁直观而广受欢迎。本文通过实战案例,介绍Python Web开发中的RESTful API设计哲学与技巧,包括使用Flask框架构建一个图书管理系统的API,涵盖资源定义、请求响应设计及实现示例。通过准确使用HTTP状态码、版本控制、错误处理及文档化等技巧,帮助你深入理解RESTful API的设计与实现。希望本文能助力你的API设计之旅。
65 3