This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
The pageshow event is sent to a Window when the browser displays the window's document due to navigation.
This includes:
Note: During the initial page load, the pageshow event fires after the load event.
Use the event name in methods like addEventListener(), or set an event handler property.
addEventListener("pageshow", (event) => { })
onpageshow = (event) => { }
A PageTransitionEvent. Inherits from Event.
PageTransitionEvent.persisted Read only
Indicates if the document is loading from a cache.
In addition to the Window interface, the event handler property onpageshow is also available on the following targets:
This example sets up event handlers for events listed in the array events. The handler, eventLogger(), logs the type of event that occurred to the console, and includes the value of the persisted flag on pageshow and pagehide events.
const events = ["pagehide", "pageshow", "unload", "load"];
const eventLogger = (event) => {
switch (event.type) {
case "pagehide":
case "pageshow": {
let isPersisted = event.persisted ? "persisted" : "not persisted";
console.log(`Event: ${event.type} - ${isPersisted}`);
break;
}
default:
console.log(`Event: ${event.type}`);
break;
}
};
events.forEach((eventName) => window.addEventListener(eventName, eventLogger));
<p> Open the console and watch the output as you navigate to and from this page. Try loading new pages into this tab, then navigating forward and backward through history, noting the events' output to the log. </p>
| Specification |
|---|
| HTML> # event-pageshow> |
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
pageshow_event |
3 | 12 | 6 | 15 | 5 | 18 | 6 | 14 | 4.2 | 1.0 | 4.4 | 4.2 |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/Window/pageshow_event