HTML : Window Event Attribute (Reference)


HTML window event attributes are used to handle browser-level events like loading, resizing, scrolling, and user interactions with the browser window. These attributes enable developers to build dynamic and responsive web applications by listening to changes or user actions.

Below is a list of all HTML window event attributes, along with concise explanations and code examples.




1. onafterprint After Print Dialog

Triggered after the print dialog is closed.

<body onafterprint=”notifyAfterPrint()”>
<script>
  function notifyAfterPrint() {
    alert(“Printing completed!”);
  }
</script>
</body>

Use Case: Reset UI elements after printing.




2. onbeforeprintBefore Print Dialog

Triggered before the print dialog appears.

<body onbeforeprint=”prepareForPrint()”>
<script>
  function prepareForPrint() {
    alert(“Preparing content for printing.”);
  }
</script>
</body>

Use Case: Adjust layout for printing.




3. onbeforeunloadBefore Page Unload

Triggered when the user attempts to leave the page.

<body onbeforeunload=”confirmExit()”>
<script>
  function confirmExit() {
    return “Are you sure you want to leave this page?”;
  }
</script>
</body>

Use Case: Warn users about unsaved changes.




4. onerrorError Handling

Triggered when an error occurs in the document.

<body onerror=”handleError(event)”>
<script>
  function handleError(event) {
    console.error(“An error occurred:”, event.message);
  }
</script>
</body>

Use Case: Log and debug errors.




5. onhashchangeURL Hash Changed

Triggered when the URL hash changes.

<body onhashchange=”handleHashChange()”>
<script>
  function handleHashChange() {
    alert(“Hash value changed!”);
  }
</script>
</body>

Use Case: Update content based on hash changes.




6. onloadPage Loaded

Triggered when the page finishes loading.

<body onload=”initPage()”>
<script>
  function initPage() {
    console.log(“Page fully loaded!”);
  }
</script>
</body>

Use Case: Initialize scripts or UI components after the page is loaded.




7. onmessageMessage Received

Triggered when the window receives a message.

<body onmessage=”receiveMessage(event)”>
<script>
  function receiveMessage(event) {
    console.log(“Message received:”, event.data);
  }
</script>
</body>

Use Case: Handle inter-window communication.




8. onofflineOffline Mode Detected

Triggered when the browser goes offline.

<body onoffline=”notifyOffline()”>
<script>
  function notifyOffline() {
    alert(“You are now offline.”);
  }
</script>
</body>

Use Case: Notify users about network disconnection.




9. ononlineOnline Mode Detected

Triggered when the browser regains an internet connection.

<body ononline=”notifyOnline()”>
<script>
  function notifyOnline() {
    alert(“You are back online.”);
  }
</script>
</body>

Use Case: Inform users about restored connectivity.




10. onpagehidePage Hidden

Triggered when the user navigates away from the page.

<body onpagehide=”handlePageHide()”>
<script>
  function handlePageHide() {
    console.log(“Page is now hidden.”);
  }
</script>
</body>

Use Case: Save the application state before leaving the page.




11. onpageshowPage Shown

Triggered when the user navigates to the page.

<body onpageshow=”handlePageShow()”>
<script>
  function handlePageShow() {
    console.log(“Page is now visible.”);
  }
</script>
</body>

Use Case: Restore the application state when the page becomes visible.




12. onpopstateBrowser History Changed

Triggered when the active history entry changes.

<body onpopstate=”handlePopState(event)”>
<script>
  function handlePopState(event) {
    console.log(“History state changed:”, event.state);
  }
</script>
</body>

Use Case: Update content dynamically when navigating browser history.




13. onresizeWindow Resized

Triggered when the browser window is resized.

<body onresize=”handleResize()”>
<script>
  function handleResize() {
    console.log(“Window resized to:”, window.innerWidth, “x”, window.innerHeight);
  }
</script>
</body>

Use Case: Adjust layout or reload components based on screen size.




14. onscrollWindow Scrolled

Triggered when the user scrolls the page.

<body onscroll=”handleScroll()”>
<script>
  function handleScroll() {
    console.log(“Scroll position:”, window.scrollY);
  }
</script>
</body>

Use Case: Implement infinite scrolling or lazy loading.



15. onstorageWeb Storage Updated

Triggered when local or session storage is updated.

<body onstorage=”handleStorageChange(event)”>
<script>
  function handleStorageChange(event) {
    console.log(“Storage key changed:”, event.key);
  }
</script>
</body>

Use Case: Synchronize state across tabs.




16. onunloadPage Unloaded

Triggered when the page is about to be unloaded.

<body onunload=”cleanup()”>
<script>
  function cleanup() {
    console.log(“Page is unloading. Cleaning up resources.”);
  }
</script>
</body>

Use Case: Save data or terminate background processes.



Summary

HTML window event attributes allow developers to monitor and respond to browser-level interactions, enabling a richer user experience. These attributes are vital for building responsive and interactive web applications. By leveraging the examples above, you can implement dynamic behaviors tailored to user actions and system events.

The article above is rendered by integrating outputs of 1 HUMAN AGENT & 3 AI AGENTS, an amalgamation of HGI and AI to serve technology education globally.

(Article By : Himanshu N)