-
-
Notifications
You must be signed in to change notification settings - Fork 213
DetachedWindowAPI
David Ortner edited this page Jan 21, 2025
·
8 revisions
DetachedWindowAPI is an API for communicating with the internal Browser in a detached Window. A Window is considered detached when the instance is created directly without going through the Browser API (e.g. new Window()
).
An instance of DetachedWindowAPI is available in the property Window.happyDOM
.
class DetachedWindowAPI
Parameter | Type | Description |
---|---|---|
browserFrame | IBrowserFrame | Browser frame. |
Property | Modifiers | Type | Description |
---|---|---|---|
settings | readonly | IBrowserSettings | Browser settings. The settings can be modified runtime. |
virtualConsolePrinter | readonly | VirtualConsolePrinter | API for reading the output of the virtual console when using a VirtualConsole. |
Method | Return type | Description |
---|---|---|
close() | Promise<void> | Closes the window and associated browser. |
waitUntilComplete() | Promise<void> | Waits for all ongoing operations to complete. This includes operations done inside loaded pages, such as loading resources and executing scripts. |
abort() | Promise<void> | Aborts all ongoing operations. |
setURL() | void | Sets URL without navigating the browser. |
setViewport() | void | Sets viewport. |
import { Window } from "happy-dom";
const window = new Window({ url: "https://localhost:3000" });
window.happyDOM.settings.navigation.userAgent =
"Mozilla/5.0 (X11; Linux x64) AppleWebKit/537.36 (KHTML, like Gecko) HappyDOM/2.0.0";
await window.happyDOM.close();
import { Window } from "happy-dom";
const window = new Window({ url: "https://localhost:3000" });
window.document.write(`
<script>
setTimeout(() => {
document.body.innerHTML = "Hello World!";
}, 10);
</script>
`);
await window.happyDOM.waitUntilComplete();
// Outputs "Hello World!"
console.log(window.document.body.innerHTML);
await window.happyDOM.close();
Help Packages