久久精品一区二区三区中文字幕-久久精品一区二区三区日韩-久久精品一区二区三区不卡-久久精品一区二区国产-久久精品一区二区-久久精品一级

技術文章
微信小程序之獲取用戶位置權限(拒絕后提醒)
發布日期:2019-06-18 閱讀次數:2294 字體大小:

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

1. wx.getLocation(多與wx.openLocation一起用)
  獲取當前的精度、緯度、速度。不需要授權。當type設置為gcj02 返回可用于wx.openLocation的坐標
2. wx.chooseLocation
  需要授權,打開地圖選擇位置

  第一次調用方法時先出現

      

  

  允許權限之后之后再出現

  

       

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

 3. wx.openLocation

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

  

      

 授權方法有三種:

1. wx.getSetting
  獲取用戶的當前設置,返回值中只會出現小程序已經向用戶請求過的權限,類似下面的樣子

  

     

2. wx.openSetting

  調起權限設置選擇界面,設置界面只會出現小程序已經向用戶請求過的權限,類似下面的樣子

  

      

   

 3. wx.authorize

  提前向用戶發起授權請求。調用后會立刻彈窗詢問用戶是否同意授權小程序使用某項功能或獲取用戶的某些數據,但不會實際調用對應接口。如果用戶之前已經同意授權,則不會出現彈窗,直接返回成功。,類似下面的樣子

  

       

  這就是wx.authorize出現的內容

 

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

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

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

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

復制代碼
var app = getApp();
Page({
   data:{
        addr:'請選擇位置'         
    },
    //選擇獲取地理位置
    getAddress:function(){
          var that=this;
      app.getPermission(that);    //傳入that值可以在app.js頁面直接設置內容    
    }, 
})
復制代碼
 最終效果圖:

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

主站蜘蛛池模板: 色综合天天综合网国产人 | 国产高清免费午夜在线视频 | 日本在线视频网址 | 嫩草影院永久在线一二三四 | 午夜在线观看免费观看 视频 | 日本xxx18hd| 成年人在线播放视频 | 日本一区二区视频在线观看 | 国产精品女主播自在线拍 | 九九成人免费视频 | 万域之王在线观看 | 朝鲜女人free性hu | 日日视频| 精品无码一区二区三区中文字幕 | 美女日b视频| 苍井空50分钟无码 | 极品主播的慰在线播放 | 窝窝午夜理伦影院 | 免费特黄一区二区三区视频一 | 轻轻操在线视频 | 国产成人在线免费观看 | 欧美一级xxx | 国产激情久久久久影院小草 | 干操网 | 国四虎影永久 | 欧美久久热 | 女性性色生活片免费观看 | 91短视频版高清在线观看免费 | 国产精品欧美韩国日本久久 | 免费观看一级一片 | 娇喘高潮教室h | 久久午夜一区二区 | 欧美日韩国产手机在线观看视频 | 水野朝阳厨房系列在线观看 | 四虎免费在线视频 | 2018av在线| 精品久久99麻豆蜜桃666 | 波多野结衣中文字幕在线 | 免费观看欧美一级高清 | pregnanthd产子 | 天天做天天爱天天爽综合网 |