<button bind:tap="toAddress" data-bind="toAddress">打开地址</button>
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
<button bind:tap="addressAgain" bindopensetting="addressAgain"> 打开地址</button>
addressAgain:function(){
wx.openSetting({
success(res) {
console.log(res.authSetting)
// res.authSetting = {
// "scope.userInfo": true,
// "scope.userLocation": true
// }
}
})
}
然后在这个addressAgain函数中调用wx.openSetting,之后就能够再次调用wx.chooseAddress了