律师微信小程序_微信小程序获取其时方位和城市

日期:2021-01-06 类型:行业动态 

关键词:小程序怎么做,凡科网小程序,微信小程序界面,线上报名小程序,微信小程序页面制作

微信小程序获取当前位置和城市名     、再停留   这篇文章主要介绍了微信小程序获取当前位置和城市名的思路,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下

  1, 获取当前地理位置,首先要拿到用户的授权wx.openSetting;

  2,微信的getLocation接口,获取当前用户的地理位置(微信返回的是经纬度,速度等参数);

  3,微信没有将经纬度直接转换为地理位置,借用腾讯位置服务中关于微信小程序的地理转换JS SDK 的API(返回信息中包括国家,省,市,区,经纬度等地理位置)
步骤描述清楚以后,下面就开始按步骤操作了;(本文仅仅讲述如何获取用户地理位置的授权)

图示为获取用户地理位置授权弹窗

在用户首次进入某页面(需要地理位置授权)时候,在页面进行onLoad,onShow时候,进行调用wx.getLocation要求用户进行授权;以后每次进入该页面时,通过wx.getSetting接口,返回用户授权具体信息。

wx.getSetting接口具体API地址链接为点击打开链接

 上图中scope.userLocation就是地理授权的标志;

当该标志是underfind,表示用户初次进入该页面,当该标志是false,表示用户初次进入该页面拒绝了地理授权,应进行重新要求获取授权。

wx.getSetting({
 success: (res) = {
 console.log(JSON.stringify(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({
 success: function (dataAu) {
 if (dataAu.authSetting["scope.userLocation"] == true) {
 wx.showToast({
 title: '授权成功',
 icon: 'success',
 duration: 1000
 //再次授权,调用wx.getLocation的API
 } else {
 wx.showToast({
 title: '授权失败',
 icon: 'none',
 duration: 1000
 } else if (res.authSetting['scope.userLocation'] == undefined) {
 //调用wx.getLocation的API
 else {
 //调用wx.getLocation的API
 })

在拿到用户授权以后,使用微信的API获取当前位置的经纬度

这里,我们进行使用的是腾讯位置服务;专为小程序开发者提供LBS数据服务工具包,可以在小程序中调用腾讯位置服务的POI检索、关键词输入提示、地址解析、逆地址解析、行政区划和距离计算等数据。 

  1,得到开发者秘钥

  2,下载微信小程序javaScriptSDK,

  3,安全域名设置,在“设置” - “开发设置”中设置request合法域名,添加

在文件中引入对应的javaScriptSDK文件

var QQMapWX = require('../../../utils/qqmap-wx-jssdk.js');
var qqma凡科抠图dk;

在文件中进行js调用

 最后的结果就是可以获得自己所在城市的具体位置了

index.js部分的代码

//index.js
//获取应用实例
const app = getApp();
var QQMapWX = require('../../../utils/qqmap-wx-jssdk.js');
var qqma凡科抠图dk;
Page({
 data: {
 province: '',
 city: '',
 latitude: '',
 longitude: ''
 onLoad: function () {
 qqma凡科抠图dk = new QQMapWX({
 key: 'XXXX-XXXX-XXXX-XXXX' //这里自己的key秘钥进行填充
 onShow: function () {
 let vm = this;
 vm.getUserLocation();
 getUserLocation: function () {
 let vm = this;
 wx.getSetting({
 success: (res) = {
 console.log(JSON.stringify(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({
 success: function (dataAu) {
 if (dataAu.authSetting["scope.userLocation"] == true) {
 wx.showToast({
 title: '授权成功',
 icon: 'success',
 duration: 1000
 //再次授权,调用wx.getLocation的API
 vm.getLocation();
 } else {
 wx.showToast({
 title: '授权失败',
 icon: 'none',
 duration: 1000
 } else if (res.authSetting['scope.userLocation'] == undefined) {
 //调用wx.getLocation的API
 vm.getLocation();
 else {
 //调用wx.getLocation的API
 vm.getLocation();
 // 微信获得经纬度
 getLocation: function () {
 let vm = this;
 wx.getLocation({
 type: 'wgs84',
 success: function (res) {
 console.log(JSON.stringify(res))
 var latitude = res.latitude
 var longitude = res.longitude
 var speed = res.speed
 var accuracy = res.accuracy;
 vm.getLocal(latitude, longitude)
 fail: function (res) {
 console.log('fail' + JSON.stringify(res))
 // 获取当前地理位置
 getLocal: function (latitude, longitude) {
 let vm = this;
 qqma凡科抠图dk.reverseGeocoder({
 location: {
 latitude: latitude,
 longitude: longitude
 success: function (res) {
 console.log(JSON.stringify(res));
 let province = res..province
 let city = res..city
 vm.setData({
 province: province,
 city: city,
 latitude: latitude,
 longitude: longitude
 fail: function (res) {
 console.log(res);
 complete: function (res) {
 // console.log(res);
})

页面展示部分的代码

 !--index.wxml-- 
 view 
 view 
 text 所在城市 /text 
 input placeholder- type='number' maxlength='50' placeholder='' bindinput="bindKeyInput" value='{{province}} {{city}}' disabled /input 
 /view 
 /view 

总结

以上所述是小编给大家介绍的微信小程序获取当前位置和城市名,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对凡科网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!