HTML5-Geolocation不允许定位后再次弹出用户权限提示

今天遇到一个奇怪的问题,同样域名,同样的JS,index.html是可以弹出定位提示框,但是product.html却不行:
https://aa.haha.com/index.html
https://aa.haha.com/aaa/product.html

google之后发现前辈文章(http://www.skyfox.org/html5-geolocation-safari-user-permission-prompt.html)
几次尝试后得出结果,这个是通过url去做得缓存,所以需要进行还原下。

解决方案就是,需要在系统中就行清理缓存的设置:

(设置)Settings -> (通用)Genera -> (重置) Reset-> (重置定位于隐私)Reset Location & Privacy.
(设置)Settings ->( 隐私)Privacy 开启 Location Services.

重新进入页面即可提示用户权限提示了!

在Safari或者在使用UIWebview的APP中当点击“不允许”选项之后webapp/html5 的定位服务不能再次显示用户权限提示框。

可以用这个源码做测试




点击这个按钮,获得您的坐标:

不管是原生iOS APP嵌入单个h5页面,还是都是h5页面的webapp也好,只要涉及到定位都会遇到这个情况。

当请求iOS开始定位的时候,会弹出一个提示框,提示你是否"允许"定位,允许定位继续下一步,如果一不小心点了下"不允许"之后,会发现,下次进到这个h5之后再也不会提示请求定位权限的提示框了。"不允许"被缓存了下来。再次调用geolocation会报 error.PERMISSION_DENIED 错误

而且没有相应的api能重启提示框。

如果说h5页面用于app中显示,可以尝试使用js与app原生交互来获取定位,原生获取定位后反传给h5,这样当整个app的定位权限被用户拒绝与开启的时候,直接到设置中对应的app下就可以恢复了。

你可能感兴趣的:(HTML5-Geolocation不允许定位后再次弹出用户权限提示)