HTML5的Geolocation地理位置定位API使用教程


Posted in HTML / CSS onMay 12, 2016

在手持设备如此普遍的今天,位置信息对于应用程序来讲是极其重要的,打车应用可以根据用户的位置信息呼叫附近的车辆,团购软件可以根据当前的位置推荐附近的影院和美食,地图应用可以根据用户的位置快速规划到目的地的路线,可以说位置信息对于移动应用是不可或缺的。
为了顺应这个潮流,HTML5为我们提供了Geolocation库,有了它我们就能够在Web应用中轻而易举地实现上述这些功能。那么今天我就为大家介绍一下这个库的使用。

基本用法 
首先,我们可以从浏览器的navigator对象中通过geolocation属性获取到一个Geolocation的实例,如下图所示:
HTML5的Geolocation地理位置定位API使用教程

图中我们可以看到,Geolocation类有三个常用的方法,他们分别是:

1.getCurrentPosition: 用于获取当前的位置信息
2.watchPosition: 用于在位置变化时实时监测位置信息
3.clearWatch: 取消正在运行的监测操作
我们先来看一下getCurrentPosition方法,下面是它的函数签名:

JavaScript Code复制内容到剪贴板
  1. navigator.geolocation.getCurrentPosition(success[, error[, options]]);  

第一个参数用于指定一个成功后的处理函数,第二参数用于指定一个错误处理函数,第三个用于给函数提供一些可选的配置项。现在我们就来调用这个函数:

JavaScript Code复制内容到剪贴板
  1. navigator.geolocation.getCurrentPosition(function(position) {   
  2.     //success handler code goes here   
  3.     console.log(position);   
  4. }, function(error) {   
  5.     //error handler code goes here   
  6.     console.log(error);   
  7. }, {//options   
  8.     enableHighAccuracy: true,   
  9.     timeout: 5000,   
  10.     maximumAge: 0   
  11. });  

一旦这段代码运行起来,浏览器窗口就会弹出一个确认框,请求用户进行位置定位的授权:
HTML5的Geolocation地理位置定位API使用教程

如果我们点击Allow允许该站点进行位置定位,该函数就开始从设备获取位置信息,并触发成功的回调函数,并将位置信息对象传入回调函数中,上面的代码中我们在控制台打印了position,控制台信息如下:
HTML5的Geolocation地理位置定位API使用教程

可以看到,position实际上是一个Geoposition对象的实例,其中包括coords和timestamp两个属性,后者是一个时间戳,记录获取到位置时的时间,coords里面包含了很多位置有关的信息:

accuracy: 位置的精确度范围,单位为米
altitude: 海拔高度,单位为米,如果设备不支持高度感应,则该属性为null
altitudeAccuracy: 海拔精确度范围,单位为米,如果设备不支持高度感应,则该属性为null
speed: 设备移动的速度,单位为米/秒,如果设备不能提供速度信息,该属性为null
heading: 当前移动的方向,以数字表示,单位为角度,以顺时针[0, 360)度表示偏离正北方的角度,0表示正北方向,90度表示正东方向,180度表示正南方向,270表示正西方向;需要注意的是,如果speed为0,则heading会是NaN,如果设备不能提供方向信息,则该属性为null
longitude: 经度信息
latitude: 纬度信息
我们在成功的回调函数中接收到这些信息,可以根据实际的设备和应用场景获取相应的信息,做进一步的操作。
回到刚才的确认框,如果我们点击了Block阻止该站点获取当前的位置信息,代码就会授权失败,相应地,失败的回调函数就会被触发,error错误对象也会被传入回调函数,我们的打印信息如下:
HTML5的Geolocation地理位置定位API使用教程

可以看到error参数是一个PositionError实例,包含一个错误码code和message,分别表示错误的类型和错误提示消息,其中错误码有以下几种:

1: PERMISSION_DENIED - 用户拒绝了授权请求,授权失败
2: POSITION_UNAVAILABLE - 因为一些内部错误,导致位置获取失败
3: TIMEOUT - 超时,超过了配置的超时时间后还未获取到位置信息
上面就是失败的回调函数,一般获取位置出现错误时,我们都要及时捕获,并做相应的处理操作,以获取好的用户体验,这一点很重要。
在上面的调用中,我们还传入了第三个参数,一个简单的对象,里面包含了几个配置信息,它们都是用来配置函数运行参数的:

enableHighAccuracy: 默认值为false,如果指定为true,则表示在设备支持的情况下,尽可能获取高精准度的数据,但这会在时间和电量方面存在一定的消耗
timeout: 用于指定一个超时时间,单位为毫秒,表示在超时后停止位置获取的操作,默认值是Infinity,表示直到获取到数据后才停止该操作的进行
maximumAge: 用于指定一个缓存位置信息的最长时间,在这个时间段内,获取位置时会从缓存中取,单位为毫秒,默认值为0,表示不使用缓存,每次都取新的数据
上面是关于getCurrentPosition方法的介绍,在某些场景下,例如路线导航应用,我们需要实时地获取最新位置,进而为用户规划最新的路线,这时,上面的方法已经不能很好的满足需求了,我们需要使用watchPosition方法:

JavaScript Code复制内容到剪贴板
  1. watchId = navigator.geolocation.watchPosition(success[, error[, options]]);  

watchPosition方法的使用方式和getCurrentPosition类似,不同的是,success函数会执行多次,一旦获取到最新的位置数据,success函数就会被触发,与之相似地,如果连续获取最新的数据失败时,error函数也会被执行多次。
大家或许会注意到,上面的函数签名中,会返回一个watchId,它标示着当前的watch操作,当我们位置跟踪任务完成后,可以使用clearWatch函数将这个watchId清除即可:

JavaScript Code复制内容到剪贴板
  1. navigator.geolocation.clearWatch(watchId);  

上面就是Geolocation的常用的三个API,日常开发中我们可根据实际情况选用合适的方法,进而获取用户的位置信息。
现在大部分浏览器都已支持Geolocation了,可是为了兼容低版本的浏览器,我们需要判断它的支持情况:

JavaScript Code复制内容到剪贴板
  1. if ('geolocation' in navigator) {   
  2.   // getting usr's position   
  3. else {   
  4.   // tips: your position is not available   
  5. }  

最后,我们用一个简单的例子来演示在开发中是如何使用Geolocation的:

JavaScript Code复制内容到剪贴板
  1. var API = {   
  2.     //get recommended data by current longitude and latitude   
  3.     getSurroundingRecommendations: function(longitude, latitude, callback) {   
  4.         //simulate data obtaining from server.   
  5.         setTimeout(function() {   
  6.             var data = [   
  7.                 {   
  8.                     //item   
  9.                 },   
  10.                 {   
  11.                     //item   
  12.                 }   
  13.             ];   
  14.             callback(data);   
  15.         }, 500);   
  16.     }   
  17. };   
  18.   
  19. document.addEventListener('DOMContentLoaded'function() {   
  20.     //detect if Geolocation is supported   
  21.     if (!'geolocation' in navigator) {   
  22.         console.log('Geolocation is not supported in your browser');   
  23.         return;   
  24.     }   
  25.   
  26.     var successHandler = function(position) {   
  27.         var coords = position.coords,   
  28.             longitude = coords.longitude,   
  29.             latitude = coords.latitude;   
  30.   
  31.         API.getSurroundingRecommendations(longitude, latitude, function(data) {   
  32.             console.log(data);   
  33.         });   
  34.     },   
  35.     errorHandler = function(error) {   
  36.         console.log(error.code, error.message);   
  37.     },   
  38.     options = {   
  39.         enableHighAccuracy: true,   
  40.         timeout: 5000,   
  41.         maximumAge: 0   
  42.     };   
  43.   
  44.     navigator.geolocation.getCurrentPosition(successHandler, errorHandler, options);   
  45.   
  46. }, false);   
  47.   

在上面的代码中,首先我们定义一个根据当前位置获取推荐数据的方法,然后在文档加载完成后,开始试图获取当前位置,并调研这个方法,获取模拟的数据,真是开发环境中,可能会进一步利用返回的数据做渲染UI等操作。

网络设备
位置服务用于估计您所在位置的本地网络信息包括:有关可见 WiFi 接入点的信息(包括信号强度)、有关您本地路由器的信息、您计算机的 IP 地址。位置服务的准确度和覆盖范围因位置不同而异。
总的来说,在PC的浏览器中 HTML5 的地理位置功能获取的位置精度不够高,如果借助这个 HTML5 特性做一个城市天气预报是绰绰有余,但如果是做一个地图应用,那误差还是太大了。不过,如果是移动设备上的 HTML5 应用,可以通过设置 enableHighAcuracy 参数为 true,调用设备的 GPS 定位来获取高精度的地理位置信息。

可选项
事实上,上述getCurrentPosition函数还支持第三个可选的参数,是一个 Option Object,一共有三个选项可以设定:

JavaScript Code复制内容到剪贴板
  1. var options = {     
  2.     enableHighAccuracy: false,     
  3.     timeout: 5000,     
  4.     maximumAge: 60000     
  5. }    

 
其中timeout是设定地理位置获取的超时时间(单位为毫秒,用户选择允许的时间不计算在内);而maximumAge表示允许设备从缓存中读取位置,缓存的过期时间,单位是毫秒,设为0来禁用缓存读取。如果返回的是缓存中的时间,会在timestamp中反映出来。
 

HTML / CSS 相关文章推荐
让IE6、IE7、IE8支持CSS3的脚本
Jul 20 HTML / CSS
css 省略号 css3让多余的字符串消失并附加省略号的实现代码
Feb 07 HTML / CSS
css3 position fixed固定居中问题解决方案
Aug 19 HTML / CSS
纯css3实现鼠标经过图片显示描述的动画效果
Sep 01 HTML / CSS
详解CSS中iconfont的使用
Aug 04 HTML / CSS
canvas烟花特效锦集
Jan 17 HTML / CSS
HTML5 Canvas绘制五星红旗
May 04 HTML / CSS
webView加载html图片遇到的问题解决
Oct 08 HTML / CSS
html5使用window.postMessage进行跨域实现数据交互的一次实战
Feb 24 HTML / CSS
HTML5+CSS+JavaScript实现捉虫小游戏设计和实现
Oct 16 HTML / CSS
POST提交数据常见的四种方式
Jan 18 HTML / CSS
CSS 左边固定宽右边自适应的6种方法
May 15 HTML / CSS
HTML5的video标签的浏览器兼容性增强方案分享
May 19 #HTML / CSS
HTML5中的postMessage API基本使用教程
May 20 #HTML / CSS
浅谈HTML5 defer和async的区别
Jun 07 #HTML / CSS
Html5上传图片 移动端、PC端通用代码
Jun 08 #HTML / CSS
你不知道的5个HTML5新功能
Jun 28 #HTML / CSS
HTML5里autofocus自动聚焦属性使用介绍
Jun 22 #HTML / CSS
HTML5 placeholder属性详解
Jun 22 #HTML / CSS
You might like
PHP数组实例总结与说明
2011/08/23 PHP
php中explode函数用法分析
2014/11/15 PHP
php语言中使用json的技巧及json的实现代码详解
2015/10/27 PHP
php单例模式的简单实现方法
2016/06/10 PHP
php+ajax实现异步上传文件或图片功能
2017/07/18 PHP
js中如何复制一个对象并获取其所有属性和属性对应的值
2013/10/24 Javascript
js 鼠标移动显示图片的简单实例
2013/12/25 Javascript
ActiveX控件与Javascript之间的交互示例
2014/06/04 Javascript
基于jQuery实现仿百度首页换肤背景图片切换代码
2015/08/25 Javascript
react.js 翻页插件实例代码
2017/01/19 Javascript
详解React中的组件通信问题
2017/07/31 Javascript
vue cli 全面解析
2018/02/28 Javascript
关于Vue Router中路由守卫的应用及在全局导航守卫中检查元字段的方法
2018/12/09 Javascript
jquery实现下载图片功能
2019/07/18 jQuery
[02:54]DOTA2英雄基础教程 撼地者
2014/01/14 DOTA
[08:04]TI4西雅图DOTA2前线报道 海涛探访各路人马
2014/07/09 DOTA
python多线程扫描端口示例
2014/01/16 Python
Python NumPy库安装使用笔记
2015/05/18 Python
python基础教程项目五之虚拟茶话会
2018/04/02 Python
对python list 遍历删除的正确方法详解
2018/06/29 Python
Python面向对象进阶学习
2019/05/21 Python
Django项目创建到启动详解(最全最详细)
2019/09/07 Python
numpy:np.newaxis 实现将行向量转换成列向量
2019/11/30 Python
Spring实战之使用util:命名空间简化配置操作示例
2019/12/09 Python
Python使用for生成列表实现过程解析
2020/09/22 Python
美国益智玩具购物网站:Fat Brain Toys
2017/11/03 全球购物
Math.round(11.5)等於多少? Math.round(-11.5)等於多少?
2015/01/27 面试题
公司部门司机岗位职责
2014/01/03 职场文书
奥林匹克运动会口号
2014/06/19 职场文书
2014年内勤工作总结
2014/11/24 职场文书
余世维讲座观后感
2015/06/11 职场文书
导游词之海南-南湾猴岛
2019/10/12 职场文书
基于Redis位图实现用户签到功能
2021/05/08 Redis
python munch库的使用解析
2021/05/25 Python
python 如何做一个识别率百分百的OCR
2021/05/29 Python
Java Lambda表达式常用的函数式接口
2022/04/07 Java/Android