我想在相同的窗口和相同的选项卡中打开一个链接,其中包含有链接的页面。

当我试图打开一个链接使用窗口。打开,然后在新选项卡中打开——而不是在同一窗口的同一选项卡中。


当前回答

像点击链接一样打开另一个url

window.location.href = "http://example.com";

其他回答

你需要使用name属性:

window.open("https://www.youraddress.com","_self")

编辑:Url前应加上协议。没有它尝试打开相对url。在Chrome 59, Firefox 54和IE 11中测试。

用这个:

location.href = "http://example.com";

在html 5中,你可以使用历史API。

history.pushState({
  prevUrl: window.location.href

}, 'Next page', 'http://localhost/x/next_page');
history.go();

然后在下一页中,您可以像这样访问状态对象

let url = history.state.prevUrl;
if (url) {
  console.log('user come from: '+ url)
}

使用_self打开当前标签页中的url

const autoOpenAlink = (url = ' ') => { 窗口。打开(url,“在同一个标签页中打开测试页面”); } <一个 href = " https://cdn.xgqfrms.xyz/index.html " 目标= " _self” onclick = " autoOpenAlink(“https://cdn.xgqfrms.xyz/index.html”)" > 在当前标签页中使用' _self '打开url < / >

在新标签页中使用_blank打开url

const autoOpenAlink = (url = ``) => { window.open(url, "open testing page in a new tab page"); } // ❌ The error is caused by a `StackOverflow` limitation // js:18 Blocked opening 'https://cdn.xgqfrms.xyz/index.html' in a new window because the request was made in a sandboxed frame whose 'allow-popups' permission is not set. <a href="https://cdn.xgqfrms.xyz/index.html" target="_blank" onclick="autoOpenAlink('https://cdn.xgqfrms.xyz/index.html')"> open url in a new tab page using `_blank` </a>

refs

根据MDN的文档,你只需要给新窗口/标签一个名字。

https://developer.mozilla.org/en-US/docs/Web/API/Window/open#Syntax

为了确保链接在同一个选项卡中打开,您应该使用window.location.replace()

请看下面的例子:

window.location.replace("http://www.w3schools.com");

来源:http://www.w3schools.com/jsref/met_loc_replace.asp