js怎么不进行跳转但是给路径带上参数

在JavaScript中,如果你想要给路径添加参数但不执行实际的跳转,你可以使用window.history.pushState方法或者window.history.replaceState方法来更新浏览器的历史记录状态,但不改变当前页面。这样你就可以给URL添加查询参数,而不会导致页面刷新或跳转。

以下是一个简单的例子,展示如何使用pushState给当前URL添加参数:

javascript 复制代码
// 获取当前URL
var currentUrl = window.location.href;
 
// 解析当前URL的查询参数
var urlParts = currentUrl.split('?');
 
// 如果URL已有查询参数,则添加新参数,否则创建新的查询字符串
var newQueryParams = 'param1=value1&param2=value2';
if (urlParts.length > 1) {
    urlParts[1] += '&' + newQueryParams;
} else {
    urlParts.push(newQueryParams);
}
 
// 创建新的URL
var newUrl = urlParts.join('?');
 
// 使用pushState更新浏览器历史记录
window.history.pushState({ path: newUrl }, '', newUrl);
 
// 现在URL已经更新,但页面不会刷新或跳转

请注意,这种方法不会向服务器发送任何请求,也不会导致页面内容改变。它只是在浏览器的历史记录中添加了一个新的记录,并更新了当前的URL。

其他文章:
History 对象的pushState()和replaceState()

相关推荐
小此方几秒前
Re: ゼロから学ぶ C++ 入門(七)类和对象·第四篇:拷贝构造函数&赋值运算符重载
开发语言·c++
一起学web前端3 分钟前
工程化懒加载的几种形式
前端·javascript·工程化
月明长歌3 分钟前
【码道初阶】【LeetCode387】如何高效找到字符串中第一个不重复的字符?
java·开发语言·数据结构·算法·leetcode·哈希算法
凯子坚持 c4 分钟前
Protobuf 序列化协议深度技术白皮书与 C++ 开发全流程指南
开发语言·c++
superman超哥5 分钟前
仓颉Union类型的定义与应用深度解析
开发语言·后端·python·c#·仓颉
智航GIS5 分钟前
1.1 Python的前世今生
开发语言·python
superman超哥6 分钟前
仓颉协变与逆变的应用场景深度解析
c语言·开发语言·c++·python·仓颉
Filotimo_6 分钟前
在java后端开发中,kafka的用处
java·开发语言
Lethehong6 分钟前
GLM-4.7 与 MiniMax M2.1 工程实测:一次性交付与长期 Agent 的分水岭
开发语言·php·ai ping·glm4.7·minimaxm2.1
学前端搞口饭吃9 分钟前
vite最新版+eslint最新版+vue3+Ts配置
javascript·vue.js·ecmascript