当前位置:   article > 正文

html定位的四种状态,HTML5定位的使用,及定位失败的原因

为什么我html开发的定位服务没有用

HTML5 Geolocation API 用于获取用户定位。该规范提供了一套保护用户隐私的机制。必须先得到用户明确许可,才能获取用户的位置信息。

定位(Geolocation)的使用

获取当前地理位置:

navigator.geolocation.getCurrentPosition(successCallback, errorCallback, options)

获取定位变化后当前地理位置:

navigator.geolocation.watchPosition(successCallback, errorCallback, options)

参数

successCallback

成功得到位置信息时的回调函数,使用Position对象作为唯一的参数。

errorCallback [可选]

获取位置信息失败时的回调函数,使用 PositionError 对象作为唯一的参数,这是一个可选项。

options [可选]

一个可选的PositionOptions对象。

Geolocation.watchPosition() 用于注册监听器,在设备的地理位置发生改变的时候自动被调用。也可以选择特定的错误处理函数。

该方法会返回一个 ID,如要取消监听可以通过 Geolocation.clearWatch() 传入该 ID 实现取消的目的。

id = navigator.geolocation.watchPosition(success[, error[, options]])

实例

var options = {

enableHighAccuracy: true,

timeout: 5000,

maximumAge: 0

};

function success(pos) {

var crd = pos.coords;

console.log('Your current position is:');

console.log('Latitude : ' + crd.latitude);

console.log('Longitude: ' + crd.longitude);

console.log('More or less ' + crd.accuracy + ' meters.');

};

function error(err) {

console.warn('ERROR(' + err.code + '): ' + err.message);

};

navigator.geolocation.getCurrentPosition(success, error, options);

定位出现失败的原因

1. 第一种情况

浏览器不支持原生定位接口,如IE较低版本的浏览器,message字段包含Browser not Support html5 geolocation信息。

2. 第二种情况

用户禁用了定位权限,需要用户开启定位权限,message字段包含Geolocation permission denied。

3. 第三种情况

浏览器禁止了非安全域的定位请求,比如Chrome、IOS10已经陆续禁止,需要升级站点到HTTPS,message字段包含Geolocation permission denied信息。注意:Chrome不会禁止localhost域名HTTP协议下的定位。

4. 第四种情况

浏览器定位超时,包括原生的超时,可以适当增加超时属性的设定值以减少这一现象。某个别浏览器本身对定位接口的友好程度较弱,也会超时返回失败,message字段包含Geolocation time out信息。

5. 第五种情况

Chrome、Firefox以及一些套壳浏览器接入的定位服务在国外,有较大的限制,也会造成定位失败,且失败率较高。

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/笔触狂放9/article/detail/166199
推荐阅读
相关标签
  

闽ICP备14008679号