navigator.geolocation定位说明
- getCurrentPosition,需要https加密SSL证书支持,http服务协议逐步启用;
- 使用PC端浏览器,部分返回的值是无法正常显示,为NULL;
navigator.geolocation.getCurrentPosition(function (position) {
console.log(position);
}, function (err) {
console.log(err.code);
}, {
enableHighAcuracy: true, //位置是否精确获取
timeout: 5000,//获取位置允许的最长时间
maximumAge: 0 //多久更新获取一次位置
})
代码分析
getCurrentPosition()返回说明
- coords.latitude:估计纬度
- coords.longitude:估计经度
- coords.altitude:估计高度
- coords.accuracy:所提供的以米为单位的经度和纬度估计的精确度
- coords.altitudeAccuracy:所提供的以米为单位的高度估计的精确度
- coords.heading: 宿主设备当前移动的角度方向,相对于正北方向顺时针计算
- coords.speed:以米每秒为单位的设备的当前对地速度
//code:返回获取位置的状态
//0:不包括其他错误编号中的错误
//1:用户拒绝浏览器获取位置信息
//2:尝试获取用户信息,但失败了
//3:设置了timeout值,获取位置超时了
positionOptions配置项
-
enableHighAccuracy 【true or false(默认)】是否返回更详细更准确的结构,默认为false不启用,选择true则启用,但是会导致较长的响应时间及增加功耗,这种情况更多的用在移动设备上。
-
timeout 设备位置获取操作的超时时间设定(不包括获取用户权限时间),单位为毫秒,如果在设定的timeout时间内未能获取位置定位,则会执行errorCallback()返回code(3)。如果未设定timeout,那么timeout默认为无穷大,如果timeout为负数,则默认timeout为0。
-
maximumAge 设定位置缓存时间,以毫秒为单位,如果不设置该值,该值默认为0,如果设定负数,则默认为0。该值为0时,位置定位时会重新获取一个新的位置对象;该值大于0时,即从上一次获取位置时开始,缓存位置对象,如果再次获取位置时间不超过maximumAge,则返回缓存中的位置,如果超出maximumAge,则重新获取一个新的位置。
@lockdata.cn