×

聊聊页面跳转window.location.href与window.open的基本应用和一些区别

作者:andy0012022.07.20来源:Web前端之家浏览:5555评论:0
关键词:js

聊聊页面跳转window.location.href与window.open的基本应用和一些区别

一、比较常用的JS跳转页面和打开新窗口的方法

1、替换当前页 (重新定位当前页)

window.location.href = "https://www.xxx.com"; // 跳转到新的域名
window.location.href = `/dashboard#/setting?type=1&userId=123`; // 在当前域名下跳转到新的子页面

window.location.href = "https://www.xxx.com"; // 跳转到新的域名
window.location.href = `/dashboard#/setting?type=1&userId=123`; // 在当前域名下跳转到新的子页面

2、打开新窗口

window.open("https://www.xxx.com"); // 跳转到新的域名
window.history.back(-1); // 返回到上一页(在当前窗口 )

二、window.location.hrefwindow.open() 的区别

区别一

window.locationwindow对象的属性  
window.open()window对象的方法

区别二

window.location.href是用新的域名替换当前页, 也就是重新定位当前页  
window.open()是用来打开一个新窗口的函数!

区别三

window.open()可能会被浏览器拦截  
window.location.href不会被窗口拦截

window.location.hrefdocument.location.href的区别:  
window.location.hrefdocument.location.href都可以对当前窗口进行重定向。  
(尽管 Document.location 是一个只读的 Location 对象,但是也能够赋给它一个 DOMString)  
当服务器未发生重定向时, 两者是相同的。  
但是当服务器发生了重定向,就不一样了:

  • document.location包含的是已经装载的URL

  • window.location.href包含的则是原始请求的文档的URL

三、window.location.href怎么跳转新窗口

window.location.href是在当前窗口进行覆盖,那怎么跳转到新窗口呢?

let tempwindow = window.open('_blank');
tempwindow.location = 'https://www.xxx.com'; // 可以打开新的地址
// tempwindow.location = '/dashboard#/setting?type=1&userId=123'; // 也可以打开原有地址的子页面

您的支持是我们创作的动力!
温馨提示:本文作者系 ,经Web前端之家编辑修改或补充,转载请注明出处和本文链接:
https://www.jiangweishan.com/article/js20220720a1.html

网友评论文明上网理性发言 已有0人参与

发表评论: