JavaScript用来改变浏览器地址栏 URL 的方法

window.location.replace(), window.location.href, 和 window.location.assign() 都是 JavaScript 用来改变浏览器地址栏 URL 并跳转到新页面的方式,但它们在 历史记录 处理上有一些不同。下面是它们的区别:

window.location.replace()

作用:
  • 用于加载一个新的 URL 替代当前页面。
  • 不会将当前页面添加到浏览器的历史记录中
何时使用:
  • 当你想要跳转到新页面,但不希望用户能够通过浏览器的"后退"按钮返回到当前页面时。
  • 比如,用户登录后,你可能不希望他们能通过点击"后退"按钮回到登录页。
示例:
javascript 复制代码
window.location.replace("https://www.example.com");
结果:
  • 用户跳转到 https://www.example.com
  • 如果用户点击"后退"按钮,不会返回到当前页面,因为当前页面没有保留在历史记录中。

window.location.href

作用:
  • 用于改变浏览器的 URL,跳转到新的页面。
  • 会将当前页面添加到浏览器的历史记录中
何时使用:
  • 当你希望跳转到新页面,并且用户仍然可以通过"后退"按钮返回到当前页面时。
示例:
javascript 复制代码
window.location.href = "https://www.example.com";
结果:
  • 用户跳转到 https://www.example.com
  • 如果用户点击"后退"按钮,会返回到当前页面,因为当前页面被保留在浏览器历史记录中。

window.location.assign()

作用:
  • 功能和 window.location.href 类似,用于加载新的 URL。
  • 会将当前页面添加到浏览器的历史记录中 ,与 href 相同。
何时使用:
  • 当你希望跳转到新页面,并且用户仍然能够通过"后退"按钮返回到当前页面时。它可以像 href 一样用来设置新的 URL。
示例:
javascript 复制代码
window.location.assign("https://www.example.com");
结果:
  • 用户跳转到 https://www.example.com
  • 如果用户点击"后退"按钮,会返回到当前页面,因为当前页面被保留在历史记录中。

总结区别

方法 历史记录行为 使用场景
window.location.replace() 不会将当前页面添加到历史记录中 不希望用户通过"后退"按钮返回当前页面
window.location.href 会将当前页面添加到历史记录中 希望用户能够通过"后退"按钮返回当前页面
window.location.assign() 会将当前页面添加到历史记录中 希望用户能够通过"后退"按钮返回当前页面

总结

  • 如果你需要避免页面跳转后用户能回到当前页面,使用 window.location.replace()
  • 如果你希望用户能够通过"后退"按钮返回到当前页面,则使用 window.location.hrefwindow.location.assign(),这两者的行为是相同的。
相关推荐
zhang238390615418 分钟前
IDEA add gitlab account 提示
java·gitlab·intellij-idea·idea
鸿蒙布道师18 分钟前
OpenAI为何觊觎Chrome?AI时代浏览器争夺战背后的深层逻辑
前端·人工智能·chrome·深度学习·opencv·自然语言处理·chatgpt
袈裟和尚24 分钟前
如何在安卓平板上下载安装Google Chrome【轻松安装】
前端·chrome·电脑
曹牧27 分钟前
HTML字符实体和转义字符串
前端·html
小希爸爸33 分钟前
2、中医基础入门和养生
前端·后端
牛马baby36 分钟前
Java高频面试之并发编程-07
java·开发语言·面试
局外人LZ36 分钟前
前端项目搭建集锦:vite、vue、react、antd、vant、ts、sass、eslint、prettier、浏览器扩展,开箱即用,附带项目搭建教程
前端·vue.js·react.js
G_GreenHand1 小时前
Dhtmlx Gantt教程
前端
鹿九巫1 小时前
【CSS】层叠,优先级与继承(四):层叠,优先级与继承的关系
前端·css
卓怡学长1 小时前
w304基于HTML5的民谣网站的设计与实现
java·前端·数据库·spring boot·spring·html5