TIMEX
TIMEX

Reputation: 271764

In Javascript, how do I "clear" the back (history -1)?

When the user loads the page, I immediately do a window redirect to another location.

The problem is, when the user clicks back, it'll go back to the page which does the redirect.

Can I "cancel" the history of the previous page? So that when the user clicks back, it goes back TWO pages instead?

Upvotes: 64

Views: 98235

Answers (3)

Rebecca
Rebecca

Reputation: 1062

For anyone coming across this page and looking for an AngularJS way to accomplish this (rather than javascript), use the $location service's replace() method (documentation) :

Use $location.url('/newpath'); or $location.path('/newpath'); as you normally would to do the redirection in angular. And then just add $location.replace(); right after it. Or you can chain the commands like this:

$location.url('/newpath').replace();

Upvotes: 3

xdazz
xdazz

Reputation: 160833

Instead of using window.location = url; to redirect,

try:

window.location.replace(url);

after using replace() the current page will not be saved in session history, meaning the user won't be able to use the Back button to navigate to it.

Upvotes: 113

T.J. Crowder
T.J. Crowder

Reputation: 1074266

You can use location.replace to replace the current location entry (the redirect page) with the new one (the target). That requires that you do the redirection via JavaScript rather than with meta tags or a 302. E.g.:

// In the redirecting page
location.replace("path/to/target/page");

Live example | Live example source

Upvotes: 9

Related Questions