HTML5 Geolocation clearWatch() API
什么是Geolocation?
Geolocation是HTML5中的API,可以用来获取用户的GIF位置。它可以获取用户位置的精确度,但其可用性因为浏览器的差异而有所不同。
示例代码1:获取用户位置
// 获取用户位置
if (navigator.geolocation) {
navigator.geolocation.getCurrentPosition(function(position) {
var lat = position.coords.latitude;
var lng = position.coords.longitude;
console.log("Your location is: " + lat + "," + lng);
});
} else {
console.log("Geolocation is not supported by this browser.");
}
示例代码2:设定位置精确度
// 设定位置精确度
var options = {
enableHighAccuracy: true,
timeout: 5000,
maximumAge: 0
};
function success(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.`);
}
function error(err) {
console.warn(`ERROR({err.code}): ${err.message}`);
}
navigator.geolocation.getCurrentPosition(success, error, options);
clearWatch() API是什么?
clearWatch()是Geolocation API中的函数,用来停止正在进行中的GIF位置的跟踪。当watchPosition()被调用时,它将返回一个唯一的ID。这个ID可以被clearWatch()函数使用,以便在任何时候停止GIF位置的跟踪。
示例代码3:停止GIF位置的跟踪
// 停止GIF位置的跟踪
var id = navigator.geolocation.watchPosition(
function success(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.`);
},
function error(err) {
console.warn(`ERROR({err.code}): ${err.message}`);
},
{
enableHighAccuracy: true,
timeout: 5000,
maximumAge: 0
}
);
navigator.geolocation.clearWatch(id); // 停止跟踪
在上面的代码中,我们首先调用watchPosition()函数来跟踪用户的GIF位置。该函数返回一个id,它可以用于停止位置的跟踪。我们使用clearWatch()来停止跟踪。
结论
Geolocation API提供了一种简单的方法来获取用户的GIF位置。在我们的示例代码中,我们看到了如何使用getCurrentPosition()和watchPosition()方法来获取位置。我们还看到了如何使用clearWatch()函数来停止正在进行中的GIF位置的跟踪。这使得Geolocation API成为开发地理位置应用程序的有用工具。