docs.rodeo

MDN Web Docs mirror

Window: pageshow event

{{APIRef("HTML DOM")}} 

The pageshow event is sent to a {{domxref("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 {{domxref("Window/load_event", "load")}}  event.

Syntax

Use the event name in methods like {{domxref("EventTarget.addEventListener", "addEventListener()")}} , or set an event handler property.

addEventListener("pageshow", (event) => {});
onpageshow = (event) => {};

Event type

A {{domxref("PageTransitionEvent")}} . Inherits from {{domxref("Event")}} .

{{InheritanceDiagram("PageTransitionEvent")}} 

Event properties

Event handler aliases

In addition to the Window interface, the event handler property onpageshow is also available on the following targets:

Examples

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 {{domxref("PageTransitionEvent.persisted", "persisted")}}  flag on pageshow and pagehide events.

JavaScript

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));

HTML

<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>

Results

{{EmbedLiveSample("Examples", 640, 250)}} 

Specifications

{{Specifications}} 

Browser compatibility

{{Compat}} 

See also

In this article

View on MDN