Вебинары Разобраться в IT Реферальная программа
Программирование Аналитика Дизайн Маркетинг Управление проектами
01 Май 2023
1 мин
2651

Изменение URL без перезагрузки страницы в JavaScript

Часто в разработке веб-страниц возникает необходимость изменить URL текущей страницы без ее перезагрузки. Это может быть полезно, например, при переходе

Часто в разработке веб-страниц возникает необходимость изменить URL текущей страницы без ее перезагрузки. Это может быть полезно, например, при переходе между вкладками на одной странице, когда хочется, чтобы в адресной строке отображалась активная вкладка, но при этом не происходила перезагрузка всей страницы.

Такую задачу можно решить с помощью метода history.pushState() в JavaScript. Этот метод позволяет добавлять новые записи в историю браузера и изменять URL без перезагрузки страницы.

Вот как это работает:

history.pushState(null, null, '/new-page.html');

В этом примере '/new-page.html' — это новый URL, который будет отображаться в адресной строке. При этом страница не будет перезагружена.

Важно отметить, что этот метод не вызывает переход на новую страницу, он только изменяет URL. Это значит, что содержимое страницы остается прежним, и для отображения нового содержимого придется использовать дополнительный код.

Также стоит учесть, что метод history.pushState() меняет только часть URL после домена. Это сделано для соблюдения политики одного источника (Same-origin policy), которая запрещает скриптам на веб-странице доступ к содержимому других сайтов.

Таким образом, с помощью метода history.pushState() можно удобно и безопасно изменять URL текущей страницы без ее перезагрузки. Это упрощает навигацию по сайту и делает работу с ним более комфортной для пользователя.

Проверь как ты усвоил материалы статьи
Пройди тест и узнай насколько ты лучше других читателей

Добавить комментарий