JS метод Geolocation.getCurrentPosition()
Загальний опис
getCurrentPosition
— це метод об'єкта navigator.geolocation
, який дозволяє отримати поточні координати користувача, такі як широта та довгота, використовуючи геолокаційні сервіси браузера. Цей метод асинхронний і приймає три параметри: функцію для обробки успішного виконання, функцію для обробки помилок та об'єкт параметрів, що дозволяє налаштувати поведінку запиту.
Функція successCallback
, яка передається як перший параметр, викликається, коли геолокація успішно отримана. Вона отримує об'єкт position
, який містить інформацію про координати користувача.
function success(position) {
console.log(`Широта: ${position.coords.latitude}`);
console.log(`Довгота: ${position.coords.longitude}`);
}
Другий параметр — це функція errorCallback
, яка викликається, якщо сталася помилка під час отримання геолокації. Вона отримує об'єкт error
, що містить код помилки і повідомлення.
function error(error) {
console.warn(`Помилка: ${error.code} - ${error.message}`);
}
Третій параметр — це об'єкт options
, який дозволяє налаштувати поведінку запиту. Наприклад, ви можете задати максимальний час на отримання геолокації або точність даних.
let options = {
enableHighAccuracy: true, // Включення високої точності
timeout: 5000, // Ліміт часу (5 секунд)
maximumAge: 0 // Не використовувати кешовані дані
};
navigator.geolocation.getCurrentPosition(success, error, options);
Цей метод зазвичай застосовується для додатків, що використовують геолокаційні сервіси, таких як картографічні сервіси або додатки для відстеження місцезнаходження користувача в реальному часі.
Порада: | Якщо ваша програма працює в середовищі з обмеженою підтримкою геолокації (наприклад, на старих браузерах або девайсах), не забувайте перевіряти підтримку API через |
Порада: | Якщо потрібно регулярно отримувати оновлене місцезнаходження користувача, замість |
Порада: | При створенні мобільних додатків, які використовують геолокацію, враховуйте, що браузери зазвичай запитують дозвіл на доступ до місцезнаходження лише один раз. Якщо користувач відмовиться, він не буде отримувати нові запити. Враховуйте це при розробці інтерфейсу. |
Синтаксис
navigator.geolocation.getCurrentPosition(successCallback, errorCallback, options);
Параметри
Return
Promise
Метод
getCurrentPosition
не повертає значення безпосередньо. Це асинхронний метод, що означає, що результат виконання обробляється через колбеки (функції зворотного виклику), які передаються як аргументи цього методу.Успішний результат: Якщо геолокація була отримана успішно, то в перший параметр функції
successCallback
передається об'єктposition
, який містить координати (широту та довготу) користувача, а також інші дані, як точність і висота (якщо доступні).- Наприклад,
position.coords.latitude
дає широту, аposition.coords.longitude
— довготу.
- Наприклад,
Помилка: Якщо виникла помилка, наприклад, користувач відмовився від надання доступу до геолокації, то другий параметр функції
errorCallback
міститиме об'єкт помилки, який включає код помилки (наприклад,PERMISSION_DENIED
,POSITION_UNAVAILABLE
, абоTIMEOUT
) і повідомлення про помилку.
Переглядачі
Переглядач | |||||
---|---|---|---|---|---|
5 |
3.5 |
5 |
10.6 |
12 |
Переглядач | ||||
---|---|---|---|---|
37 |
18 |
4 |
3 |
Переглядач | ||
---|---|---|
- |
- |
Приклади
У цьому прикладі користувач натискає кнопку для того, щоб отримати свої координати. Якщо дозволено доступ до геолокації, результат (широта та довгота) виводиться на екран. Якщо доступ заблоковано або інша помилка, користувач побачить відповідне повідомлення. Цей приклад демонструє роботу з API геолокації, обробку помилок і взаємодію з користувачем через кнопку та відображення результатів на сторінці.
Цей приклад показує, як за допомогою геолокації користувача отримати його координати та на основі цих даних виконати запит до API для пошуку найближчих ресторанів. Це корисно в додатках, що надають користувачам інформацію про місця поруч.
navigator.geolocation.getCurrentPosition(function(position) {
const latitude = position.coords.latitude;
const longitude = position.coords.longitude;
fetch(`https://api.yelp.com/v3/businesses/search?term=restaurants&latitude=${latitude}&longitude=${longitude}`)
.then(response => response.json())
.then(data => {
data.businesses.forEach(restaurant => {
console.log(`${restaurant.name} - ${restaurant.location.address1}`);
});
})
.catch(error => console.error("Помилка при пошуку ресторанів:", error));
}, function(error) {
console.error("Не вдалося отримати геолокацію:", error);
});
У цьому прикладі ми отримуємо точне місцезнаходження користувача для використання у службах доставки. Це дозволяє точно визначити, де знаходиться користувач, і доставити товар саме до цієї точки.
navigator.geolocation.getCurrentPosition(function(position) {
const latitude = position.coords.latitude;
const longitude = position.coords.longitude;
console.log(`Точне місцезнаходження: Широта: ${latitude}, Довгота: ${longitude}`);
// Наприклад, тут можна передавати ці координати до служби доставки.
}, function(error) {
console.error("Не вдалося отримати геолокацію:", error);
});