小程序用户拒绝地址授权之后,wx.openSetting不管用,怎么再次打开授权

 

toAddress:function(){
        wx.getSetting({//调用wx.getSetting接口查看用户设置
          success(res) {
            if(!res.authSetting["scope.address"]){//如果用户没有打开地址授权的话,弹出地址授权请求
              wx.authorize({
                scope: 'scope.address',
                success:res=>{
             //用户点击允许之后就可以获取地址了,使用wx.chooseAddress接口
                  wx.chooseAddress({
                    success:res=>{
                  
                    }
                  })
                },
                fail:res=>{
//如果用户点击了拒绝,就会走fail
                  console.log("点击了拒绝,authorize--fail用户拒绝过");
                 
                }
              })
            }else{
//如果用户打开过地址授权,则可以直接选择地址
              wx.chooseAddress({
              success:res=>{ }
                })
              }
            })
            }
        }
    })
    
    
  },

如果授权按钮弹窗请求用户授权地址信息之后,用户点击了拒绝。再次点击该按钮就会没有反应,调用wx.openSetting也是不管用的。因为这个接口不允许小程序自己主动调用用户的设置页面。

所以,需要用户拒绝之后,可以将之前的按钮替换为:!!!必须用这个button才可以再次打开授权,为了让用户看不出区别,可以自行在页面放一个一摸一样的button,在有授权时显示上文的button,在无授权时显示这个button。表面看着一样,其实是两个不同的button
 

addressAgain:function(){
    wx.openSetting({
      success(res) {
        console.log(res.authSetting)
        // res.authSetting = {
        //   "scope.userInfo": true,
        //   "scope.userLocation": true
        // }
      }
    })
  }

然后在这个addressAgain函数中调用wx.openSetting,之后就能够再次调用wx.chooseAddress了

果授权按钮弹窗请求用户授权地址信息之后,用户点击了拒绝。再次点击该按钮就会没有反应

你可能感兴趣的:(微信小程序)