微信小程序获取当前的位置

news/2024/7/20 2:33:09 标签: 微信小程序, 小程序, 前端

小程序>微信小程序获取位置信息的方式有两种,一种是调用微信官方的接口来获取,如getLocation,这种方式只能获取经纬度
微信官方文档

https://developers.weixin.qq.com/miniprogram/dev/api/location/wx.getLocation.html

在这里插入图片描述

另一种是使用的第三方平台的,比如本文章使用的是 腾讯地图

小程序>微信小程序JavaScript SDK / 开发指南 / 入门及使用限制-开发文档

https://lbs.qq.com/miniProgram/jsSdk/jsSdkGuide/jsSdkOverview


1 腾讯位置开发基本步骤

1.1 申请开发者密钥(key)

申请密钥 :登录腾讯开发者平台,然后创建应用,如下图
在这里插入图片描述

开通webserviceAPI服务:控制台 ->应用管理 -> 我的应用 ->添加key-> 勾选WebServiceAPI -> 保存

在这里插入图片描述

(小程序SDK需要用到webserviceAPI的部分服务,所以使用该功能的KEY需要具备相应的权限)

1.2 下载小程序>微信小程序JavaScriptSDK

下载小程序>微信小程序JavaScriptSDK

https://mapapi.qq.com/web/miniprogram/JSSDK/qqmap-wx-jssdk1.2.zip

下载后解压,拷贝到小程序>微信小程序项目中
在这里插入图片描述

1.3 安全域名设置

安全域名设置,在小程序管理后台 -> 开发 -> 开发管理 -> 开发设置 -> “服务器域名” 中设置request合法域名,添加

https://apis.map.qq.com

在这里插入图片描述

1.4 小程序>微信小程序设置隐私权限

在app.json 文本中添加

  "permission": {
    "scope.userLocation": {
      "desc": "小程序需要使用您的位置信息 已确认您的采样地址"
    }
  },
  "requiredPrivateInfos": [
    "getLocation"
  ],

getLocation 是使用微信接口来获取经纬度时使用,需要申请调用权限。
在这里插入图片描述

3 获取位置信息

核心代码如下:

// 引入SDK核心类,js文件根据自己业务,位置可自行放置
var QQMapWX = require('../../libs/qqmap-wx-jssdk.js');
var qqmapsdk;
Page({
 
    onLoad: function () {
        // 实例化API核心类
        qqmapsdk = new QQMapWX({
            key: '申请的key'
        });
    },
    onShow: function () {
        // 调用接口
        qqmapsdk.reverseGeocoder({
            success: function (res) {
                let result = res.result;
                console.log(res.status, res.message);
            },
            fail: function (res) {
                console.log(res.status, res.message);
            },
            complete: function (res) {
            console.log(res.status, res.message);
        }
     });
  }
})

4 权限问题

当用户第一次进入页面获取位位置信息时,小程序会弹出请求位置权限申请,如果用户点击了拒绝权限,那下次进入时,将不会再次弹出权限申请,所以这个过程需要开发者来维护处理一下。

如果用户拒绝过,再次进入后,弹框提示用户开启权限

  //定位方法
  initLocationPersmiss: function () {
    var _this = this;
    wx.getSetting({
      success: (res) => {
        // res.authSetting['scope.userLocation'] == undefined  表示 初始化进入该页面
        // res.authSetting['scope.userLocation'] == false  表示 非初始化进入该页面,且未授权
        // res.authSetting['scope.userLocation'] == true  表示 地理位置授权
        if (res.authSetting['scope.userLocation'] != undefined && res.authSetting['scope.userLocation'] != true) {
          //未授权
          wx.showModal({
            title: '请求授权当前位置',
            content: '需要获取您的地理位置,请确认授权',
            success: function (res) {
              if (res.cancel) {
                //取消授权
                wx.showToast({
                  title: '拒绝授权 暂时无法使用本功能',
                  icon: 'none',
                  duration: 1000
                })
              } else if (res.confirm) {
                //确定授权,通过wx.openSetting发起授权请求
                wx.openSetting({
                  success: function (res) {
                    if (res.authSetting["scope.userLocation"] == true) {
                      wx.showToast({
                        title: '授权成功',
                        icon: 'success',
                        duration: 1000
                      })
                      //再次授权,调用wx.getLocation的API
                      _this.initGetLocationFlunction();
                    } else {
                      wx.showToast({
                        title: '授权失败',
                        icon: 'none',
                        duration: 1000
                      })
                    }
                  }
                })
              }
            }
          })
        } else if (res.authSetting['scope.userLocation'] == undefined) {
          //用户首次进入页面,调用wx.getLocation的API
          _this.initGetLocationFlunction();
        } else {
          console.log('授权成功')
          //调用wx.getLocation的API
          _this.initGetLocationFlunction();
        }
      }
    })

  },

获取位置的请求

initGetLocationFlunction(isRefresh){
    let that = this;
    this.setData({isUpdateLocatin:true})
    qqmapsdk.reverseGeocoder({
      success: function(res) {
        let result = res.result;
        console.log(res);
      },
      fail: function(res) {
        console.log(res.status, res.message);
       
      },
      complete: function(res) {
        console.log(res.status, res.message);
      }
    })
  },

完毕


http://www.niftyadmin.cn/n/1603.html

相关文章

云呐|动环监控有什么作用?动环监控系统的监控对象有哪些?

机房动环FSU监控系统是一套应对机房环境监控的系统。它可以24小时实时监控辖区内的机房环境,防止事故造成的危害,帮助我们降低机房的运维成本和机器的运行成本。现阶段,基站动环FSU监控系统早已应用于多个项目,协助企业节约30%以上…

(02)Cartographer源码无死角解析-(09) gflags与glog简介、及其main函数讲解

本人讲解关于slam一系列文章汇总链接:史上最全slam从零开始,针对于本栏目讲解(02)Cartographer源码无死角解析-接如下: (02)Cartographer源码无死角解析- (00)目录_最新无死角讲解:https://blog.csdn.net/weixin_43013761/article/details/127350885 文…

java计算机毕业设计高校贫困生信息管理系统源码+mysql数据库+系统+lw文档+部署

java计算机毕业设计高校贫困生信息管理系统源码mysql数据库系统lw文档部署 java计算机毕业设计高校贫困生信息管理系统源码mysql数据库系统lw文档部署本源码技术栈: 项目架构:B/S架构 开发语言:Java语言 开发软件:idea eclipse…

【C++初阶-类和对象下】嗯...这样对劲多了

前言 博主水平有限,不足之处如能斧正,感激不尽! 通过前两篇类和对象的讲解,我们对类和对象有了大概的认识,此篇主要是补充类和对象的其他语法,主要有: 构造函数相关 初始化列表explicit关键字…

ER 图与数据字典 – 哪个更适合记录数据模型

什么是数据模型? 数据模型是以数据元素及其关系列表的形式对现实世界的一个方面的抽象表示。 可以使用各种技术对数据进行建模 - 关系建模中的实体关系图,面向对象建模中的UML类图,数据字典,维度建模,仅举几例。 什…

GitCode / 1024程序员开源挑战赛实践

奖品设置及发放规则 序号任务名称任务奖励领取条件发放规则人数限制1GitCode平台基础操作一年10核10G云实验环境会员(非云服务器,是云容器实验环境,详细介绍戳我查看)完成任务即可发放,用户可按照任务操作步骤自行检查…

redux的@reduxjs/toolkit + Hooks用法

新特性的出现都是解决了旧用法的一些不足之处 ! 1. 下载 reduxjs/toolkit npm install reduxjs/toolkit 再下载 react-redux npm install react-redux // 这里还要用到react-redux, 是因为连接组件和数据的时候, 仍然使用的是react-redux&a…

【Linux练习生】线程池

本节知识所需代码已同步到gitee-> https://gitee.com/ZMZZZhao/linux-git/tree/master/thread_pool本文收录于专栏:Linux关注作者,持续阅读作者的文章,学习更多知识! https://blog.csdn.net/weixin_53306029?spm1001.2014.300…