本篇作者:©大史不说话——Chinasoft Frontend Web Developer
简介:JavaScript30 是 Wes Bos 推出的一个 30 天挑战。项目免费提供了 30 个视频教程、30 个挑战的起始文档和 30 个挑战解决方案源代码。目的是帮助人们用纯 JavaScript 来写东西,不借助框架和库,也不使用编译器和引用。现在你看到的是这系列指南的第 21 篇。完整指南在 GitHub,喜欢请 Star 哦♪(^∇^*)
创建时间:2017-09-08
最后更新:2017-09-11
本次的挑战任务,是利用浏览器内置Web Geolocation API
,将获取到的地理位置及相关坐标,与index-start.html
中的可视化指南针连接在一起。
由于笔记本电脑一般不带速度及方向传感器,从结果中可以看到返回值中heading
及speed
键值均为null
,为演示可视化效果,代码中采用手动赋值的方式进行演示。
1.有关地理位置接口Geolocation
的说明,可查看MDN中的相关解释。
2.getCurrentPosition()
方法和watchPosition()
方法
getCurrentPosition()
方法在调用时返回一次相关信息,watchPosition()
方法调用后将持续返回相关信息,两个方法调用时除了传入相关的回调函数外,还需要传入options
配置对象作为第三参数,options
相关键值如下:
enableHighAccuracy
参数表示是否高精度可用,为Boolean类型,默认为false,如果开启,响应时间会变慢,同时,在手机设备上会用掉更多的流量,也就是money了。timeout
参数表示等待响应的最大时间,默认是0毫秒,表示无穷时间。maximumAge
表示应用程序的缓存时间。单位毫秒,默认是0,意味着每次请求都是立即去获取一个全新的对象内容。
1.使用getCurrentPosition()
方法获得相关信息
if(navigator.geolocation){
navigator.geolocation.getCurrentPosition(success, error, options);
}else{
console.log('Your broswer does not support the Geolocation API');
}
2.当成功返回结果时,在控制台输出结果,并根据结果对相应的DOM元素进行样式调整
function success(pos) {
console.log(pos);
var crd = pos.coords;
console.log('Your current position is:');
console.log('Latitude : ' + crd.latitude);
console.log('Longitude: ' + crd.longitude);
console.log('More or less ' + crd.accuracy + ' meters.');
//改变传感器速度值和罗盘的指向
speed.innerHTML = crd.speed;
arrow.style.transform = `rotate(${crd.heading}deg)`;
};