[英]How to delete multiple url params
There is a problem with deleting several string parameters.删除多个字符串参数时出现问题。 Only the last parameter is being deleted now.现在只删除最后一个参数。
upd : I did not specify that I wanted to achieve the ability to remove specific parameter values upd : 我没有指定我想要实现移除特定参数值的能力
this code does not work correctly:此代码无法正常工作:
const updateFiltersSearchParams = (paramKey, newValue) => {
const isParamExist = searchParams.getAll(paramKey).includes(newValue);
if (!isParamExist) {
searchParams.append(paramKey, newValue);
setSearchParams(searchParams);
} else {
const updatedSearchParams = new URLSearchParams(
[...searchParams].filter(
([key, value]) => key !== paramKey || value !== newValue
)
);
setSearchParams(updatedSearchParams);
}
};
const handleDeleteParams = () => {
[...checkboxParams].forEach((param) => {
updateFiltersSearchParams("selected", param);
});
};
change your handleDeleteParams
function with this用这个改变你的handleDeleteParams
function
const handleDeleteParams = () => {
setSearchParams([]);
};
If you want to delete * only the selected
( or any specific queryString key ) queryString parameters you can use the delete
method of the URLSearchParams
object, then enqueue the params URL update.如果您想删除 *仅selected
的(或任何特定的 queryString 键)queryString 参数,您可以使用URLSearchParams
object 的delete
方法,然后将参数 URL 更新入队。
const handleDeleteParams = (key) => {
searchParams.delete(key);
setSearchParams(searchParams);
};
... ...
<button type="button" onClick={() => handleDeleteParams("selected")}>
Clear all "selected" params
</button>
Solved the problem by modifying the function like this通过像这样修改 function 解决了这个问题
const toggleSearchParams = (params) => {
const newSearchParams = [...searchParams];
for (const prevParam of params) {
const index = newSearchParams.findIndex(
(newParam) =>
prevParam[0] === newParam[0] && prevParam[1] === newParam[1]
);
if (index === -1) {
newSearchParams.push(prevParam);
} else {
newSearchParams.splice(index, 1);
}
}
setSearchParams(new URLSearchParams(newSearchParams));
};
const handleChangeCheckBoxValue = (e) => {
toggleSearchParams([["selected", e.target.value]]);
};
const handleDeleteParams = () => {
toggleSearchParams(checkboxParams.map((param) => ["selected", param]));
};
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.