user1065055
user1065055

Reputation: 5791

Open URL in same window and in same tab

I want to open a link in the same window and in the same tab that contains the page with the link.

When I try to open a link by using window.open, then it opens in new tab—not in the same tab in the same window.

Upvotes: 572

Views: 1443177

Answers (16)

tic glass
tic glass

Reputation: 26

if you are using APP SCRIPT then this is the solution:

<a id='someID' href='<?= ScriptApp.getService().getUrl(); ?>?requiredTab' hidden></a>

$("#someID")[0].click();

Upvotes: 0

xgqfrms
xgqfrms

Reputation: 12136

open url in the current tab page using _self

const autoOpenAlink = (url = ``) => {
  window.open(url, "open testing page in a same tab page");
}
<a
 href="https://cdn.xgqfrms.xyz/index.html"
 target="_self"
 onclick="autoOpenAlink('https://cdn.xgqfrms.xyz/index.html')">
   open url in the current tab page using `_self`
</a>

open url in a new tab page using _blank

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

According to MDN's docs, you just need to give one name of the new window/tab.

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

Upvotes: 5

I-am-developer-9
I-am-developer-9

Reputation: 494

You can do

window.close();
window.open("index.html");

and it worked successfully on my website.

Upvotes: 0

Cepheus
Cepheus

Reputation: 4893

In order to ensure that the link is opened in the same tab, you should use window.location.replace()

See the example below:

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

Source: http://www.w3schools.com/jsref/met_loc_replace.asp

Upvotes: 114

Siddharth Shukla
Siddharth Shukla

Reputation: 1131

   Just Try in button.

   <button onclick="location.reload();location.href='url_name'" 
   id="myButton" class="btn request-callback" >Explore More</button>

   Using href 

  <a href="#" class="know_how" onclick="location.reload();location.href='url_name'">Know More</a> 

Upvotes: 0

Tom Berthold
Tom Berthold

Reputation: 552

You can have it go to the same page without specifying the url:

window.open('?','_self');

Upvotes: 48

vdbuilder
vdbuilder

Reputation: 12964

You need to use the name attribute:

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

Edit: Url should be prepended with protocol. Without it tries to open relative url. Tested in Chrome 59, Firefox 54 and IE 11.

Upvotes: 960

thanglv
thanglv

Reputation: 39

Exactly like this window.open("www.youraddress.com","_self")

Upvotes: 2

Adi Prasetyo
Adi Prasetyo

Reputation: 1042

With html 5 you can use history API.

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

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

Then on the next page you can access state object like so

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

Upvotes: 2

DarckBlezzer
DarckBlezzer

Reputation: 4764

Open another url like a click in link

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

Upvotes: 12

Samit
Samit

Reputation: 74

Thats pretty easy. Open first window as window.open(url, <tabNmae>)

Example: window.open("abc.com",'myTab')

and for next all window.open, use same tab name instead of _self, _parent etc.

Upvotes: 1

Muaz Khan
Muaz Khan

Reputation: 7236

One of the most prominent javascript features is to fire onclick handlers on the fly. I found following mechanism more reliable than using location.href='' or location.reload() or window.open:

// this function can fire onclick handler for any DOM-Element
function fireClickEvent(element) {
    var evt = new window.MouseEvent('click', {
        view: window,
        bubbles: true,
        cancelable: true
    });

    element.dispatchEvent(evt);
}

// this function will setup a virtual anchor element
// and fire click handler to open new URL in the same room
// it works better than location.href=something or location.reload()
function openNewURLInTheSameWindow(targetURL) {
    var a = document.createElement('a');
    a.href = targetURL;
    fireClickEvent(a);
}

Above code is also helpful to open new tab/window and bypassing all pop-up blockers!!! E.g.

function openNewTabOrNewWindow(targetURL) {
    var a = document.createElement('a');
    a.href = targetURL;

    a.target = '_blank'; // now it will open new tab/window and bypass any popup blocker!

    fireClickEvent(a);
}

Upvotes: 12

Magesh
Magesh

Reputation: 393

If you have your pages inside "frame" then "Window.open('logout.aspx','_self')"

will be redirected inside same frame. So by using

"Window.open('logout.aspx','_top')"

we can load the page as new request.

Upvotes: 22

ijse
ijse

Reputation: 3035

window.open(url, wndname, params), it has three arguments. if you don't want it open in the same window, just set a different wndname. such as :

window.open(url1, "name1", params); // this open one window or tab
window.open(url1, "name2", params); // though url is same, but it'll open in another window(tab).

Here is the details about window.open(), you can trust it!
https://developer.mozilla.org/en/DOM/window.open

have a try ~~

Upvotes: 6

Dave L.
Dave L.

Reputation: 9781

Use this:

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

Upvotes: 208

Jeffrey Zhao
Jeffrey Zhao

Reputation: 5023

Do you have to use window.open? What about using window.location="http://example.com"?

Upvotes: 11

Related Questions