html5 navigator.geolocation基于浏览器获取地理位置代码案例
一、简介
html5为window.navigator提供了geolocation属性,用于获取基于浏览器的当前用户地理位置。
window.navigator.geolocation提供了3个方法分别是:
void getCurrentPosition(onSuccess,onError,options);//获取用户当前位置int watchCurrentPosition(onSuccess,onError,options);//持续获取当前用户位置void clearWatch(watchId);//watchId 为watchCurrentPosition返回的值//取消监控options = { enableHighAccuracy,//boolean 是否要求高精度的地理信息 timeout,//获取信息的超时限制 maximumAge//对地理信息进行缓存的时间}//options可以不写,为默认即可
二、position对象
当成功获取地理位置信息时候,onsuccess方法中会返回position对象,通过这个对象可以获取地理位置的相关信息,包括:
立即学习“前端免费学习笔记(深入)”;
position对象的属性: latitude,//纬度longitude,//经度altitude,//海拔高度accuracy,//获取纬度或者经度的精度altitudeAccurancy,//海拔高度的精度heading,//设备前景方向。正北方向的顺时针旋转角speed,//设备的前进速度 m/stimestamp,//获取地理位置信息时候的时间
三、基于google map的例子
直接看代码:
<!DOCTYPE HTML><html><head> <meta charset="UTF-8"> <title>在页面上使用google地图示例</title></head><body onload = 'init()'> <div id="map" style='width:800px;height:800px;'></div> <script type="text/javascript" src='http://maps.google.com/maps/api/js?sensor=false'></script> <script type="text/javascript"> function init(){ if(navigator.geolocation){ navigator.geolocation.getCurrentPosition(function(pos){ var coords = pos.coords; var latlng =new google.maps.LatLng(coords.latitude,coords.longitude); var options = {zoom:14,center:latlng,mapTypeId : google.maps.MapTypeId.ROADMAP}; var map1; map1 =new google.maps.Map(document.getElementById('map'),options); var marker =new google.maps.Marker({ position : latlng, map : map1 }); var infowindow =new google.maps.InfoWindow({ content : '当前位置!' }); infowindow.open(map1,marker); }); } } </script> </body></html>