21 Geolocation 中文指南

优质
小牛编辑
126浏览
2023-12-01

挑战任务

本次的挑战任务,是利用浏览器内置Web Geolocation API,将获取到的地理位置及相关坐标,与index-start.html中的可视化指南针连接在一起。

实现效果

结果展示
由于笔记本电脑一般不带速度及方向传感器,从结果中可以看到返回值中headingspeed键值均为null,为演示可视化效果,代码中采用手动赋值的方式进行演示。

相关知识

1.有关地理位置接口Geolocation的说明,可查看MDN中的相关解释。

2.getCurrentPosition()方法和watchPosition()方法
getCurrentPosition()方法在调用时返回一次相关信息,watchPosition()方法调用后将持续返回相关信息,两个方法调用时除了传入相关的回调函数外,还需要传入options配置对象作为第三参数,options相关键值如下:

  • enableHighAccuracy参数表示是否高精度可用,为Boolean类型,默认为false,如果开启,响应时间会变慢,同时,在手机设备上会用掉更多的流量,也就是money了。
  • timeout参数表示等待响应的最大时间,默认是0毫秒,表示无穷时间。
  • maximumAge表示应用程序的缓存时间。单位毫秒,默认是0,意味着每次请求都是立即去获取一个全新的对象内容。

过程指南

1.使用getCurrentPosition()方法获得相关信息

  1. if(navigator.geolocation){
  2. navigator.geolocation.getCurrentPosition(success, error, options);
  3. }else{
  4. console.log('Your broswer does not support the Geolocation API');
  5. }

2.当成功返回结果时,在控制台输出结果,并根据结果对相应的DOM元素进行样式调整

  1. function success(pos) {
  2. console.log(pos);
  3. var crd = pos.coords;
  4. console.log('Your current position is:');
  5. console.log('Latitude : ' + crd.latitude);
  6. console.log('Longitude: ' + crd.longitude);
  7. console.log('More or less ' + crd.accuracy + ' meters.');
  8. //改变传感器速度值和罗盘的指向
  9. speed.innerHTML = crd.speed;
  10. arrow.style.transform = `rotate(${crd.heading}deg)`;
  11. };