位置: IT常识 - 正文

微信小程序获取当前的位置(微信小程序获取地理位置)

编辑:rootadmin
微信小程序获取当前的位置

推荐整理分享微信小程序获取当前的位置(微信小程序获取地理位置),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:微信小程序获取手机号失败,微信小程序获取地理位置,微信小程序获取地理位置,微信小程序获取手机号收费,微信小程序获取手机号上限怎么办,微信小程序获取手机号,微信小程序获取手机号失败,微信小程序获取手机号失败,内容如对您有帮助,希望把文章链接给更多的朋友!

微信小程序获取位置信息的方式有两种,一种是调用微信官方的接口来获取,如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); } }) },

完毕

本文链接地址:https://www.jiuchutong.com/zhishi/299211.html 转载请保留说明!

上一篇:Linux内核学习笔记——页表的那些事。(《linux内核分析》)

下一篇:常用HTML5开发工具有哪些?(html5开发的app有哪些)

  • 个人所得税退税操作流程
  • 分期收款企业所得税调整
  • 公司个人薪金怎么申报宁波
  • 净资产增加额计算公式
  • 企业资产核算不包括哪些
  • 房地产老项目增值税简易计税
  • 小规模纳税人销售不动产适用税率
  • 计提出口关税会计分录
  • 广告费支出限额
  • 长期待摊费用当月增加当月摊销吗
  • 发票丢失能直接作废吗
  • 物业服务合同印花算什么类型
  • 房产税怎么计算的
  • 商砼税收政策
  • 反倾销税税率查询
  • 增值税确认平台一直显示该网站出现问题
  • 小规模纳税人自开专票
  • 工程未结算能主张工程款吗
  • 长期应付款怎么冲减
  • 失去胜诉权但又有起诉权是什么意思
  • 重置申报清册之前的税需要重新申报吗
  • 没有证书可以报特长生吗
  • 契税减免备案材料是什么
  • 实行简易征收
  • 办理出口退税的流程
  • centos 6.5安装教程
  • 国家减免税收
  • postman入门
  • windows dvd maker是什么
  • 企业接受母公司代为缴纳税款会计分录
  • islp2sta.exe - islp2sta是什么进程 有什么作用
  • 无形资产摊销时点
  • 处置固定资产增值税怎么计算
  • 最小的手机有多大
  • 允许税前扣除的税金
  • 这是我见过最牛的人英语
  • web主要的请求方式有几种
  • dmsetup remove_all 会不会清掉数据
  • 经费支出的定义
  • mongodb服务端默认的端口号是多少?
  • db2udb
  • 出售其他债权投资产生的收益为什么计入留存收益
  • 公司向股东借款多久必须归还
  • 采购供应部门发挥的作用
  • 2020年增值税税收政策
  • 主营业务收入借贷方
  • 调研费属于什么会计科目
  • 接受控股股东赠与的一项非货币性资产
  • 私募基金如何做账
  • 员工奖励账务处理流程
  • 小规模红冲发票怎么做分录
  • 股权转让如何办理
  • 预付账款科目的余额如果在借方,则在资产负债表上
  • 营业外支出包括哪些?
  • 银行利息为什么用红字
  • 营业外收入适用的会计准则
  • 农民专业合作社属于什么经济类型
  • 技术服务类有哪些
  • Linux/UNIX和Window平台上安装Mysql
  • mac怎么用知云翻译
  • system idle process是什么进程(CPU的空闲率)
  • win8系统对电脑配置要求
  • win双系统怎么切换
  • application error message 漏洞验证
  • linux判断程序是否运行
  • Win10装不上是什么原因
  • ExtJS 2.0实用简明教程之应用ExtJS
  • CCProgressTimer 进度条动画在cocos2dx+lua中的使用
  • iframe transparent透明背景方法
  • pycharm中连接MySQL数据库
  • python itcast
  • Android开发工具
  • Linux bash Shell中的变量类型详解
  • js中ajax完整例子
  • js中substr,substring,indexOf,lastIndexOf,split,replace的用法详解
  • javascript要学哪些
  • 2023年新农合缴费
  • 成立税务师事务所一定要执业会员吗
  • 办理养殖照税务登记证
  • 车辆购置税怎么做账
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设