国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 課堂 > 小程序 > 正文

微信小程序出現wx.getLocation再次授權問題的解決方法分析

2020-03-21 16:03:22
字體:
來源:轉載
供稿:網友

本文實例講述了微信小程序出現wx.getLocation再次授權問題的解決方法。分享給大家供大家參考,具體如下:

首先,在page外定義一個公共函數用于發送獲取位置的請求

var getLocation = function (that) { wx.getLocation({  type: 'wgs84',  success: function (res) {   // 經緯度   var latitude = res.latitude   var longitude = res.longitude   var aK = that.data.aK   wx.request({    url: 'https://api.map.baidu.com/geocoder/v2/?ak=' + aK + '&location=' + latitude + ',' + longitude + '&output=json',    data: {},    header: {     'content-type': 'application/json'    },    success: function (res) {     var city = res.data.result.addressComponent.city;     that.setData({      currentCity: city     })     wx.request({      url: 'xxx' + city,      data: {},      header: {       'content-type': 'application/json'      },      success: function (res) {       that.setData({        county: res.data,       })      },     })    }   })  },  fail: function () {   wx.showToast({    title: '授權失敗',    icon: 'success',    duration: 1000   })  } })}

然后,在page中需要位置調用page外部的getLocation 函數

wx.getSetting({    success: (res) => {     if (res.authSetting['scope.userLocation'] != undefined && res.authSetting['scope.userLocation'] != true) {//非初始化進入該頁面,且未授權      wx.showModal({       title: '是否授權當前位置',       content: '需要獲取您的地理位置,請確認授權,否則無法獲取您所需數據',       success: function (res) {        if (res.cancel) {         that.setData({          isshowCIty: false         })         wx.showToast({          title: '授權失敗',          icon: 'success',          duration: 1000         })        } else if (res.confirm) {         wx.openSetting({          success: function (dataAu) {           if (dataAu.authSetting["scope.userLocation"] == true) {            wx.showToast({             title: '授權成功',             icon: 'success',             duration: 1000            })            //再次授權,調用getLocationt的API            getLocation(that);           } else {            wx.showToast({             title: '授權失敗',             icon: 'success',             duration: 1000            })           }          }         })        }       }      })     } else if (res.authSetting['scope.userLocation'] == undefined) {//初始化進入      getLocation(that);     }     else { //授權后默認加載      getLocation(that);     }    }})

上述過程執行順序為:

1.先加載wx.getLocation彈出自己的授權框,如圖

微信小程序,wx.getLocation,授權

然后,點擊確定即可授權,若點擊取消則取消授權,當再次需要授權時,會調用我們自定義的Modal框,如圖

微信小程序,wx.getLocation,授權

其次,針對上述的Modal框點擊取消則關閉,若點擊確定則打開手機的地址授權設置,如圖

微信小程序,wx.getLocation,授權

最后,若直接點擊左上方的返回箭頭則取消授權,若先選中地理位置按鈕,然后在點擊左上方的返回箭頭則授權成功,如圖

微信小程序,wx.getLocation,授權

希望本文所述對大家微信小程序開發有所幫助。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 邛崃市| 隆德县| 枣强县| 神池县| 东台市| 观塘区| 肃北| 榆林市| 广州市| 牟定县| 朝阳区| 湾仔区| 吴旗县| 永年县| 凤城市| 太原市| 辉南县| 泰宁县| 景泰县| 比如县| 哈尔滨市| 晋中市| 武胜县| 南安市| 枣强县| 冀州市| 宝山区| 金塔县| 专栏| 衢州市| 神池县| 政和县| 沙坪坝区| 铁岭市| 罗定市| 郎溪县| 中阳县| 惠州市| 永靖县| 克什克腾旗| 石泉县|