JS властивість Object.history
Загальний опис
Window.history - це властивість об'єкта Window у JavaScript, яка надає доступ до історії сесії браузера, зокрема, до стеку історії (history stack). Ця властивість є частиною Browsing History API і дозволяє розробникам керувати навігацією та історією сторінок у межах одного сеансу браузера. Основна користь полягає у можливості програмного керування історією переходів користувача в межах одного веб-додатку, що робить взаємодію з додатком більш гнучкою та контрольованою.
Використання Window.history включає методи, які дозволяють додавати, змінювати та переміщуватися по записам історії. Наприклад, метод history.pushState() дозволяє додати запис у історію переходів, а history.back() - повернутися на одну сторінку назад, що імітує натискання кнопки "Назад" у браузері.
Простий приклад використання:
// Додавання нового запису до історії
history.pushState({page: 1}, "title 1", "?page=1");
// Повернення на один крок назад у історії
history.back();
Складніший приклад:
// Змінення поточного стану
history.replaceState({page: 2}, "title 2", "?page=2");
// Перехід на два кроки вперед у історії
history.go(2);
Ці методи дозволяють розробникам створювати глибшу інтерактивність у веб-додатках, забезпечуючи кращий досвід користування без перезавантаження сторінки. Особливо це корисно в односторінкових додатках (SPA), де керування історією дозволяє імітувати навігацію між сторінками.
Давайте детальніше розглянемо методи:
history.pushState(state, title, [url])- цей метод дозволяє додати запис до історії сесії без перезавантаження сторінки. Аргументstate- об'єкт, який відноситься до нового стану,title- заголовок стану (більшість браузерів це ігнорують), іurl- нова URL-адреса.history.replaceState(state, title, [url])- замінює поточний запис у історії на новий, з аналогічними параметрами, що й уpushState.history.back()- емулює натискання кнопки "Назад" у браузері.history.forward()- емулює натискання кнопки "Вперед".history.go(delta)- переміщується на кілька кроків вперед або назад у історії, в залежності від знаку і величиниdelta.
Важливо пам'ятати, що зміни в історії, зроблені за допомогою Window.history, не призводять до негайного перезавантаження сторінки, але вони можуть вплинути на поведінку кнопок "Назад" та "Вперед" браузера. Розробникам слід ретельно планувати використання цих методів, щоб забезпечити інтуїтивно зрозумілу та ефективну навігацію в додатку.
| Порада: | Використовуйте методи |
| Порада: | Використовуйте властивість |
| Порада: | Будьте уважні, використовуючи |
| Порада: | Для SPA, де навігація контролюється JavaScript, |
Синтаксис
window.history
Значення
Return
Переглядачі
| Переглядач | |||||
|---|---|---|---|---|---|
1 |
1 |
1 |
3 |
12 |
| Переглядач | ||||
|---|---|---|---|---|
4.4 |
18 |
4 |
1 |
| Переглядач | ||
|---|---|---|
- |
- |
Приклади
У цьому прикладі ми створили додаток, який має дві кнопки: "Назад" і "Вперед". Користувач може натискати ці кнопки, і за допомогою властивості history браузера відбувається навігація між різними сторінками в історії браузера. Це демонструє, як можна використовувати властивість history для контролю навігації в додатку на JavaScript.
У цьому прикладі ми перевіряємо, чи історія браузера має попередню сторінку за допомогою властивості length. Якщо є попередня сторінка, ми створюємо кнопку "Назад", і при кліку на неї користувач переходить на попередню сторінку в історії браузера.
// Перевіряємо, чи історія браузера має попередню сторінку
if (window.history.length > 1) {
// Додаємо кнопку "Назад" на сторінку
var backButton = document.createElement("button");
backButton.textContent = "Назад";
backButton.addEventListener("click", function() {
// Переходимо на попередню сторінку в історії браузера
window.history.back();
});
document.body.appendChild(backButton);
}
У цьому складнішому прикладі ми спершу отримуємо поточний URL. Потім створюємо кнопку "Змінити URL", і при її кліку ми генеруємо новий URL та додаємо запис до історії браузера за допомогою pushState(). Ми також слухаємо подію popstate, щоб відобразити поточний URL в консолі браузера при зміні URL без перезавантаження сторінки.
// Отримуємо поточний URL
var currentURL = window.location.href;
// Додаємо кнопку "Змінити URL"
var changeURLButton = document.createElement("button");
changeURLButton.textContent = "Змінити URL";
changeURLButton.addEventListener("click", function() {
// Генеруємо новий URL
var newURL = currentURL + "?new_param=123";
// Додаємо запис до історії браузера і змінюємо URL без перезавантаження
window.history.pushState(null, null, newURL);
});
document.body.appendChild(changeURLButton);
// Обробляємо подію зміни URL
window.addEventListener("popstate", function(event) {
// Відобразити поточний URL в консолі
console.log("Поточний URL: " + window.location.href);
});
