H5地理定位navigator.geolocation的使用(获取经纬度、海拔高度等设备信息)
         
                原创
        
    
    
                
             ©著作权归作者所有:来自51CTO博客作者漏刻有时的原创作品,请联系作者获取转载授权,否则将追究法律责任        
            
                    
                
navigator.geolocation定位说明
 
 
- getCurrentPosition,需要https加密SSL证书支持,http服务协议逐步启用;
- 使用PC端浏览器,部分返回的值是无法正常显示,为NULL;
 
 
H5定位代码
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:以米每秒为单位的设备的当前对地速度
 
 
errorCallback 定位失败时执行的回调函数
    //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,则重新获取一个新的位置。