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

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以及一些套壳浏览器接入的定位服务在国外,有较大的限制,也会造成定位失败,且失败率较高。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值