UrlSearchParams не обновляет URL

Я пытаюсь добавить поиск и страницу к своему URL-адресу для поиска и разбиения на страницы на странице.

 const urlParams = new URLSearchParams(window.location.search);
if (!urlParams.has('search'){
   urlParams.append('search', question);
}
if (!urlParams.has('page'){
   urlParams.append('page', pageIndex);
}

Кажется, это ничего не делает с фактическим URL-адресом. Но когда я вызываю urlParams.toString() тогда я вижу, что они были добавлены, но их нет в фактическом URL-адресе в браузере.

Я использую Chrome 107, поэтому он должен его поддерживать. Я что-то пропустил?

Документация мне пока не помогла.

Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
0
178
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Вы можете попробовать так:

Сначала извлеките текущий path. Затем добавьте urlParams к полученному пути и используйте history.pushState(), чтобы установить новый URL-адрес.

const question = "the question";
const pageIndex = 3;

const urlParams = new URLSearchParams(window.location.search);

if (! urlParams.has('search')) {
   urlParams.append('search', question);
}

if (! urlParams.has('page')) {
   urlParams.append('page', pageIndex);
}

const path = window.location.href.split('?')[0];
const newURL = `${path}?${urlParams}`;

history.pushState({}, '', newURL);

Источники:

Ответ принят как подходящий

Конечно, это ничего не делает с фактическим URL-адресом, вы создаете объект URLParameters и обновляете его. что вам не хватает:

window.loacation.search = urlParams.toString()

он изменит строку запроса в URL-адресе браузера и перезагрузит страницу.

если вы не заинтересованы в перезагрузке страницы, вы можете использовать объект history DOM

let url = new URL(window.location.href);
if (!(url.searchParams.has('search'))){
   url.searchParams.append('search', question);
}
if (!(url.searchParams.has('page'))){
   url.searchParams.append('page', pageIndex);
}
history.pushState({},'',url.href);

наконец, если вы все равно хотите обновить параметры page и search, вы можете использовать метод url.searchParams.set(), например:

url.searchParams.set('page', pageIndex);

он добавит параметр, если он не существует, и обновит его, если он существует, без создания исключений.

Другие вопросы по теме