溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

發(fā)布時間:2020-10-05 07:51:05 來源:腳本之家 閱讀:1176 作者:站住,別跑 欄目:web開發(fā)

微信小程序獲取用戶當前位置有三個方式:

1. wx.getLocation(多與wx.openLocation一起用)

  獲取當前的精度、緯度、速度。不需要授權(quán)。當type設(shè)置為gcj02 返回可用于wx.openLocation的坐標

2. wx.chooseLocation

  需要授權(quán),打開地圖選擇位置

  第一次調(diào)用方法時先出現(xiàn)

  微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

  允許權(quán)限之后之后再出現(xiàn)

  微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

  如果第一次就不允許,則一直調(diào)用wx.chooseLocation的fail方法

3. wx.openLocation

  需要授權(quán),使用微信內(nèi)置地圖查看位置。多半用于查看起點到終點的路線怎么走

  微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

授權(quán)方法有三種:

1. wx.getSetting

  獲取用戶的當前設(shè)置,返回值中只會出現(xiàn)小程序已經(jīng)向用戶請求過的權(quán)限,類似下面的樣子

  微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

2. wx.openSetting

  調(diào)起權(quán)限設(shè)置選擇界面,設(shè)置界面只會出現(xiàn)小程序已經(jīng)向用戶請求過的權(quán)限,類似下面的樣子

  微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

3. wx.authorize

  提前向用戶發(fā)起授權(quán)請求。調(diào)用后會立刻彈窗詢問用戶是否同意授權(quán)小程序使用某項功能或獲取用戶的某些數(shù)據(jù),但不會實際調(diào)用對應(yīng)接口。如果用戶之前已經(jīng)同意授權(quán),則不會出現(xiàn)彈窗,直接返回成功。,類似下面的樣子

微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)  

這就是wx.authorize出現(xiàn)的內(nèi)容

問題來了:假如我第一次使用wx.chooseLocation()獲取權(quán)限被拒絕,然后使用wx.getSetting()來重新獲取權(quán)限該怎么做呢?

思路:wx.chooseLocation()有fail方法,如果第一次拒絕之后,以后調(diào)用選擇地圖都是觸發(fā)的這個,那么我可以在fail方法里面,使用wx.getSetting(),這樣就每次都能判斷是否已經(jīng)給與了權(quán)限了。

第一步:由于有可能會多次使用定位的方法,所以我把定位的方法寫到App.js中,方便調(diào)用

App({
 //獲取用戶地理位置權(quán)限
 getPermission:function(obj){
  wx.chooseLocation({
  success: function (res) { 
   obj.setData({
    addr: res.address  //調(diào)用成功直接設(shè)置地址
   })    
  },
  fail:function(){
   wx.getSetting({
    success: function (res) {
     var statu = res.authSetting;
     if (!statu['scope.userLocation']) {
      wx.showModal({
       title: '是否授權(quán)當前位置',
       content: '需要獲取您的地理位置,請確認授權(quán),否則地圖功能將無法使用',
       success: function (tip) {
        if (tip.confirm) {
         wx.openSetting({
          success: function (data) {
           if (data.authSetting["scope.userLocation"] === true) {
            wx.showToast({
             title: '授權(quán)成功',
             icon: 'success',
             duration: 1000
            })
            //授權(quán)成功之后,再調(diào)用chooseLocation選擇地方
            wx.chooseLocation({
             success: function(res) {
              obj.setData({
               addr: res.address
              })
             },
            })
           } else {
            wx.showToast({
             title: '授權(quán)失敗',
             icon: 'success',
             duration: 1000
            })
           }
          }
         })
        }
       }
      })
     }
    },
    fail: function (res) {
     wx.showToast({
      title: '調(diào)用授權(quán)窗口失敗',
      icon: 'success',
      duration: 1000
     })
    }
   })
  }
 })  
 },
}) 

第二步:在需要獲取地址的頁面中:

var app = getApp();
Page({
 data:{
  addr:'請選擇位置'   
 },
 //選擇獲取地理位置
 getAddress:function(){
   var that=this;
  app.getPermission(that); //傳入that值可以在app.js頁面直接設(shè)置內(nèi)容 
 }, 
})

最終效果圖:

微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

最終在手機上獲取到的位置偏差不太大。

--------------------------------------------------------------------------------

更新 wx.openSetting 的注意事項。

2.3.0 版本開始,用戶發(fā)生點擊行為后,才可以跳轉(zhuǎn)打開設(shè)置頁,管理授權(quán)信息

即2.3.0版本之后,我通過上面的wx.showModal的回調(diào)函數(shù)來調(diào)用wx.openSetting 會發(fā)生下面的錯誤:

openSetting:fail can only be invoked by user TAP gesture.

但是我測試 2.2.4 開始 到2.3.1 都會出現(xiàn)上面這種錯誤。

2.3.2及以上又不會出現(xiàn)這種問題。。。。。。。。

而且當我測試2.0.8 到 2.2.3 會出現(xiàn)下面的錯誤。。。。。。

微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒)

其它的就沒有這問題了。搞不懂。。。

總結(jié)

以上所述是小編給大家介紹的微信小程序用戶位置權(quán)限的獲取方法(拒絕后提醒),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對億速云網(wǎng)站的支持!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI