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()

相关推荐
小林敲代码77889 分钟前
记一次 Vue 项目首屏优化:从 7.1s 到 0.9s,深挖 Gzip 的力量
前端·javascript·vue.js
前路不黑暗@17 分钟前
Java项目:Java脚手架项目的公共模块的实现(二)
java·开发语言·spring boot·学习·spring cloud·maven·idea
人道领域18 分钟前
Spring核心注解全解析
java·开发语言·spring boot
云深麋鹿42 分钟前
标准库中的String类
开发语言·c++·容器
Highcharts.js1 小时前
什么是向量图表?如何用 Highcharts 快速创建一个笛卡尔坐标图/矢量图?
javascript·开发文档·highcharts·图表开发·向量图·矢量图表·笛卡尔坐标图
脱离语言2 小时前
Jeecg3.8.2 前端经验汇总
开发语言·前端·javascript
MOONICK2 小时前
C#基础入门
java·开发语言
NEXT062 小时前
useMemo 与 useCallback 的原理与最佳实践
前端·javascript·react.js
小爱丨同学2 小时前
React-Context用法汇总 +注意点
前端·javascript·react.js
女王大人万岁2 小时前
Golang标准库 CGO 介绍与使用指南
服务器·开发语言·后端·golang