经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 移动开发 » 微信小程序 » 查看文章
微信、企微小程序使用taro对位置权限进行处理
来源:cnblogs  作者:story.Write(z)  时间:2024/4/23 16:54:24  对本文有异议

1.功能

当用户未授权地理位置权限时,引导用户开启地理位置权限,区别于之前的uni处理,uni的处理 的处理没有手机系统关闭位置权限的处理,但是uni文章中对于打开位置权限后重新返回小程序有做权限重获取,当前文章未做处理

2.无授权情况分为(截图示例为iphone手机)

2.1 手机系统未开启位置授权 无法通过代码跳转到该设置页面

image

2.2 微信、企微App未授权 可以通过代码跳转设置页面

image
image

2.3 小程序未授权 可以通过代码跳转设置页面

image

3.代码

其中$dialog为提示框,具有确认取消按钮,点击后会执行对应逻辑可以换成对应项目的组件

  1. async function checkAndAuthLocationAuth(): Promise<boolean> {
  2. return new Promise(async (resolve, reject) => {
  3. const systemRes = await taro.getSystemInfo()
  4. if (!systemRes.locationEnabled) {
  5. $dialog({
  6. title: '提示',
  7. render: () => '当前系统,未开启定位权限,请在设置中开启系统定位权限!',
  8. cancelButton: true,
  9. confirmButton: true,
  10. handleConfirm: async () => {
  11. }
  12. })
  13. return reject(false)
  14. } else {
  15. const appAuthorizeSetting = await taro.getAppAuthorizeSetting()
  16. const appAuthObj = {
  17. title: '提示',
  18. render: () =>
  19. '当前App未开启定位权限,请在设置中开启App定位权限!',
  20. cancelButton: true,
  21. confirmButton: true,
  22. handleConfirm: async () => {
  23. taro.openAppAuthorizeSetting({})
  24. }
  25. }
  26. switch (appAuthorizeSetting.locationAuthorized) {
  27. case 'authorized':
  28. const wxMiniSetting = await taro.getSetting()
  29. if (wxMiniSetting.authSetting['scope.userLocation']) {
  30. // 成功获取后你可以直接根据项目业务需求决定此处是否直接获取经纬度等
  31. return resolve(true)
  32. }else if (wxMiniSetting.authSetting['scope.userLocation'] === undefined) {
  33. const authRes = await taro.authorize({ scope: 'scope.userLocation' })
  34. if (authRes.errMsg === 'authorize:ok') {
  35. // 成功获取后你可以直接根据项目业务需求决定此处是否直接获取经纬度等
  36. resolve(true)
  37. } else {
  38. // 拒绝后这里可以直接再次提示以及一些业务逻辑处理
  39. }
  40. }
  41. else {
  42. $dialog({
  43. title: '提示',
  44. render: () =>
  45. '您的账号尚未获取或已拒绝“获取位置信息”,暂时无法使用该功能,是否确认授权?',
  46. cancelButton: true,
  47. confirmButton: true,
  48. handleConfirm: async () => {
  49. taro.openSetting({})
  50. },
  51. })
  52. }
  53. return reject(false)
  54. case 'denied':
  55. $dialog(appAuthObj)
  56. return reject(false)
  57. case 'not determined':
  58. $dialog(appAuthObj)
  59. return reject('')
  60. default:
  61. break;
  62. }
  63. }
  64. })
  65. }

使用示例

  1. await checkAndAuthLocationAuth()
  2. // 业务逻辑 如果未成功获取则不会走到业务逻辑代码中
  3. ...
  4. ...
  5. // 业务逻辑结束

原文链接:https://www.cnblogs.com/coderzdz/p/18153241

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号