1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
|
---
title: Window
slug: Web/API/Window
tags:
- API
- DOM
- Interface
- JavaScript
- NeedsTranslation
- Reference
- Tab
- TopicStub
- Window
translation_of: Web/API/Window
---
<div>{{APIRef("DOM")}}</div>
<p><span class="seoSummary">The <strong><code>Window</code></strong> interface represents a window containing a DOM document; the <code>document</code> property points to the <a href="/en-US/docs/DOM/document">DOM document</a> loaded in that window.</span> A window for a given document can be obtained using the {{domxref("document.defaultView")}} property.</p>
<p>A global variable, <code>window</code>, representing the window in which the script is running, is exposed to JavaScript code.</p>
<p>The <code>Window</code> interface is home to a variety of functions, namespaces, objects, and constructors which are not necessarily directly associated with the concept of a user interface window. However, the <code>Window</code> interface is a suitable place to include these items that need to be globally available. Many of these are documented in the <a href="/en-US/docs/Web/JavaScript/Reference">JavaScript Reference</a> and the <a href="/en-US/docs/Web/API/Document_Object_Model" title="/en-US/docs/Web/API/Document_Object_Model">DOM Reference</a>.</p>
<p>In a tabbed browser, each tab is represented by its own <code>Window</code> object; the global <code>window</code> seen by JavaScript code running within a given tab always represents the tab in which the code is running. That said, even in a tabbed browser, some properties and methods still apply to the overall window that contains the tab, such as {{Domxref("Window.resizeTo", "resizeTo()")}} and {{Domxref("Window.innerHeight", "innerHeight")}}. Generally, anything that can't reasonably pertain to a tab pertains to the window instead.</p>
<p>{{InheritanceDiagram}}</p>
<h2 id="Properties">Properties</h2>
<p><em>This interface inherits properties from the {{domxref("EventTarget")}} interface and implements properties from the {{domxref("WindowOrWorkerGlobalScope")}} and {{domxref("WindowEventHandlers")}} mixins.</em></p>
<p>Note that properties which are objects (e.g.,. for overriding the prototype of built-in elements) are listed in a separate section below.</p>
<dl>
<dt>{{domxref("Window.closed")}} {{Non-standard_inline}} {{readOnlyInline}}</dt>
<dd>This property indicates whether the current window is closed or not.</dd>
<dt>{{domxref("Window.console")}} {{ReadOnlyInline}}</dt>
<dd>Returns a reference to the console object which provides access to the browser's debugging console.</dd>
<dt>{{domxref("Window.content")}} and Window._content {{Non-standard_inline}} {{obsolete_inline}} {{ReadOnlyInline}}</dt>
<dd>Returns a reference to the content element in the current window. Since Firefox 57 (initially Nightly-only), both versions are only available from chrome (privileged) code, and not available to the web anymore.</dd>
<dt>{{domxref("Window.controllers")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
<dd>Returns the XUL controller objects for the current chrome window.</dd>
<dt>{{domxref("Window.customElements")}} {{ReadOnlyInline}}</dt>
<dd>returns a reference to the {{domxref("CustomElementRegistry")}} object, which can be used to register new <a href="/en-US/docs/Web/Web_Components/Using_custom_elements">custom elements</a> and get information about previously registered custom elements.</dd>
<dt>{{domxref("Window.crypto")}} {{readOnlyInline}}</dt>
<dd>Returns the browser crypto object.</dd>
<dt>{{domxref("Window.defaultStatus")}} {{Obsolete_inline("gecko23")}}</dt>
<dd>Gets/sets the status bar text for the given window.</dd>
<dt>{{domxref("Window.devicePixelRatio")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
<dd>Returns the ratio between physical pixels and device independent pixels in the current display.</dd>
<dt>{{domxref("Window.dialogArguments")}} {{ReadOnlyInline}}</dt>
<dd>Gets the arguments passed to the window (if it's a dialog box) at the time {{domxref("window.showModalDialog()")}} was called. This is an {{Interface("nsIArray")}}.</dd>
<dt>{{domxref("Window.directories")}} {{obsolete_inline}}</dt>
<dd>Synonym of {{domxref("window.personalbar")}}</dd>
<dt>{{domxref("Window.document")}} {{ReadOnlyInline}}</dt>
<dd>Returns a reference to the document that the window contains.</dd>
<dt>{{domxref("Window.DOMMatrix")}} {{readOnlyInline}} {{experimental_inline}}</dt>
<dd>Returns a reference to a {{domxref("DOMMatrix")}} object, which represents 4x4 matrices, suitable for 2D and 3D operations.</dd>
<dt>{{domxref("Window.DOMMatrixReadOnly")}} {{readOnlyInline}} {{experimental_inline}}</dt>
<dd>Returns a reference to a {{domxref("DOMMatrixReadOnly")}} object, which represents 4x4 matrices, suitable for 2D and 3D operations.</dd>
<dt>{{domxref("Window.DOMPoint")}} {{readOnlyInline}} {{experimental_inline}}</dt>
<dd>Returns a reference to a {{domxref("DOMPoint")}} object, which represents a 2D or 3D point in a coordinate system.</dd>
<dt>{{domxref("Window.DOMPointReadOnly")}} {{readOnlyInline}} {{experimental_inline}}</dt>
<dd>Returns a reference to a {{domxref("DOMPointReadOnly")}} object, which represents a 2D or 3D point in a coordinate system.</dd>
<dt>{{domxref("Window.DOMQuad")}} {{readOnlyInline}} {{experimental_inline}}</dt>
<dd>Returns a reference to a {{domxref("DOMQuad")}} object, which provides represents a quadrilaterial object, that is one having four corners and four sides.</dd>
<dt>{{domxref("Window.DOMRect")}} {{readOnlyInline}} {{experimental_inline}}</dt>
<dd>Returns a reference to a {{domxref("DOMRect")}} object, which represents a rectangle.</dd>
<dt>{{domxref("Window.DOMRectReadOnly")}} {{readOnlyInline}} {{experimental_inline}}</dt>
<dd>Returns a reference to a {{domxref("DOMRectReadOnly")}} object, which represents a rectangle.</dd>
<dt>{{domxref("Window.event")}} {{ReadOnlyInline}}</dt>
<dd>Returns the <strong>current event</strong>, which is the event currently being handled by the JavaScript code's context, or <code>undefined</code> if no event is currently being handled. The {{domxref("Event")}} object passed directly to event handlers should be used instead whenever possible.</dd>
<dt>{{domxref("Window.frameElement")}} {{readOnlyInline}}</dt>
<dd>Returns the element in which the window is embedded, or null if the window is not embedded.</dd>
<dt>{{domxref("Window.frames")}} {{readOnlyInline}}</dt>
<dd>Returns an array of the subframes in the current window.</dd>
<dt>{{domxref("Window.fullScreen")}} {{gecko_minversion_inline("1.9")}}</dt>
<dd>This property indicates whether the window is displayed in full screen or not.</dd>
<dt>{{domxref("Window.globalStorage")}} {{gecko_minversion_inline("1.8.1")}} {{Non-standard_inline}} {{Obsolete_inline("gecko13")}}</dt>
<dd>Unsupported since Gecko 13 (Firefox 13). Use {{domxref("Window.localStorage")}} instead.<br>
Was: Multiple storage objects that are used for storing data across multiple pages.</dd>
<dt>{{domxref("Window.history")}} {{ReadOnlyInline}}</dt>
<dd>Returns a reference to the history object.</dd>
<dt>{{domxref("Window.innerHeight")}} {{readOnlyInline}}</dt>
<dd>Gets the height of the content area of the browser window including, if rendered, the horizontal scrollbar.</dd>
<dt>{{domxref("Window.innerWidth")}} {{readOnlyInline}}</dt>
<dd>Gets the width of the content area of the browser window including, if rendered, the vertical scrollbar.</dd>
<dt>{{domxref("Window.isSecureContext")}} {{experimental_inline}} {{readOnlyInline}}</dt>
<dd>Indicates whether a context is capable of using features that require secure contexts.</dd>
<dt>{{domxref("Window.length")}} {{readOnlyInline}}</dt>
<dd>Returns the number of frames in the window. See also {{domxref("window.frames")}}.</dd>
<dt>{{domxref("Window.location")}}</dt>
<dd>Gets/sets the location, or current URL, of the window object.</dd>
<dt>{{domxref("Window.locationbar")}} {{ReadOnlyInline}}</dt>
<dd>Returns the locationbar object, whose visibility can be toggled in the window.</dd>
<dt>{{domxref("Window.localStorage")}} {{readOnlyInline}} {{gecko_minversion_inline("1.9.1")}}</dt>
<dd>Returns a reference to the local storage object used to store data that may only be accessed by the origin that created it.</dd>
<dt>{{domxref("Window.menubar")}} {{ReadOnlyInline}}</dt>
<dd>Returns the menubar object, whose visibility can be toggled in the window.</dd>
<dt>{{domxref("Window.messageManager")}} {{gecko_minversion_inline("2.0")}}</dt>
<dd>Returns the <a href="/en-US/docs/The_message_manager">message manager</a> object for this window.</dd>
<dt>{{domxref("Window.mozAnimationStartTime")}} {{ReadOnlyInline}} {{gecko_minversion_inline("2.0")}} {{Deprecated_inline}}</dt>
<dd>The time in milliseconds since epoch at which the current animation cycle began. Use {{domxref("Animation.startTime")}} instead.</dd>
<dt>{{domxref("Window.mozInnerScreenX")}} {{ReadOnlyInline}} {{non-standard_inline}} {{gecko_minversion_inline("1.9.2")}}</dt>
<dd>Returns the horizontal (X) coordinate of the top-left corner of the window's viewport, in screen coordinates. This value is reported in CSS pixels. See <code>mozScreenPixelsPerCSSPixel</code> in {{interface("nsIDOMWindowUtils")}} for a conversion factor to adapt to screen pixels if needed.</dd>
<dt>{{domxref("Window.mozInnerScreenY")}} {{ReadOnlyInline}} {{non-standard_inline}} {{gecko_minversion_inline("1.9.2")}}</dt>
<dd>Returns the vertical (Y) coordinate of the top-left corner of the window's viewport, in screen coordinates. This value is reported in CSS pixels. See <code>mozScreenPixelsPerCSSPixel</code> for a conversion factor to adapt to screen pixels if needed.</dd>
<dt>{{domxref("Window.mozPaintCount")}} {{non-standard_inline}} {{ReadOnlyInline}} {{gecko_minversion_inline("2.0")}}</dt>
<dd>Returns the number of times the current document has been rendered to the screen in this window. This can be used to compute rendering performance.</dd>
<dt>{{domxref("Window.name")}}</dt>
<dd>Gets/sets the name of the window.</dd>
<dt>{{domxref("Window.navigator")}} {{readOnlyInline}}</dt>
<dd>Returns a reference to the navigator object.</dd>
<dt>{{domxref("Window.opener")}}</dt>
<dd>Returns a reference to the window that opened this current window.</dd>
<dt>{{domxref("Window.orientation")}} {{non-standard_inline}} {{deprecated_inline}} {{readOnlyInline}}</dt>
<dd>Returns the orientation in degrees (in 90 degree increments) of the viewport relative to the device's natural orientation.</dd>
<dt>{{domxref("Window.outerHeight")}} {{readOnlyInline}}</dt>
<dd>Gets the height of the outside of the browser window.</dd>
<dt>{{domxref("Window.outerWidth")}} {{readOnlyInline}}</dt>
<dd>Gets the width of the outside of the browser window.</dd>
<dt>{{domxref("Window.scrollX","Window.pageXOffset")}} {{readOnlyInline}}</dt>
<dd>An alias for {{domxref("window.scrollX")}}.</dd>
<dt>{{domxref("Window.scrollY","Window.pageYOffset")}} {{readOnlyInline}}</dt>
<dd>An alias for {{domxref("window.scrollY")}}</dd>
<dt>{{domxref("Window.parent")}} {{readOnlyInline}}</dt>
<dd>Returns a reference to the parent of the current window or subframe.</dd>
<dt>{{domxref("Window.performance")}} {{readOnlyInline}}</dt>
<dd>Returns a {{domxref("Performance")}} object, which includes the {{domxref("Performance.timing", "timing")}} and {{domxref("Performance.navigation", "navigation")}} attributes, each of which is an object providing <a href="/en-US/docs/Navigation_timing">performance-related</a> data. See also <a href="/en-US/docs/Web/API/Navigation_timing_API/Using_Navigation_Timing">Using Navigation Timing</a> for additional information and examples.</dd>
<dt>{{domxref("Window.personalbar")}} {{readOnlyInline}}</dt>
<dd>Returns the personalbar object, whose visibility can be toggled in the window.</dd>
<dt>{{domxref("Window.pkcs11")}} {{obsolete_inline(29)}}</dt>
<dd>Formerly provided access to install and remove PKCS11 modules.</dd>
<dt>{{domxref("Window.returnValue")}}</dt>
<dd>The return value to be returned to the function that called {{domxref("window.showModalDialog()")}} to display the window as a modal dialog.</dd>
<dt>{{domxref("Window.screen")}} {{readOnlyInline}}</dt>
<dd>Returns a reference to the screen object associated with the window.</dd>
<dt>{{domxref("Window.screenX")}} {{readOnlyInline}}</dt>
<dd>Returns the horizontal distance of the left border of the user's browser from the left side of the screen.</dd>
<dt>{{domxref("Window.screenY")}} {{readOnlyInline}}</dt>
<dd>Returns the vertical distance of the top border of the user's browser from the top side of the screen.</dd>
<dt>{{domxref("Window.scrollbars")}} {{readOnlyInline}}</dt>
<dd>Returns the scrollbars object, whose visibility can be toggled in the window.</dd>
<dt>{{domxref("Window.scrollMaxX")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
<dd>The maximum offset that the window can be scrolled to horizontally, that is the document width minus the viewport width.</dd>
<dt>{{domxref("Window.scrollMaxY")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
<dd>The maximum offset that the window can be scrolled to vertically (i.e., the document height minus the viewport height).</dd>
<dt>{{domxref("Window.scrollX")}} {{readOnlyInline}}</dt>
<dd>Returns the number of pixels that the document has already been scrolled horizontally.</dd>
<dt>{{domxref("Window.scrollY")}} {{readOnlyInline}}</dt>
<dd>Returns the number of pixels that the document has already been scrolled vertically.</dd>
<dt>{{domxref("Window.self")}} {{ReadOnlyInline}}</dt>
<dd>Returns an object reference to the window object itself.</dd>
<dt>{{domxref("Window.sessionStorage")}}</dt>
<dd>Returns a reference to the session storage object used to store data that may only be accessed by the origin that created it.</dd>
<dt>{{domxref("Window.sidebar")}} {{non-standard_inline}} {{ReadOnlyInline}}</dt>
<dd>Returns a reference to the window object of the sidebar.</dd>
<dt>{{domxref("Window.speechSynthesis")}} {{ReadOnlyInline}}</dt>
<dd>Returns a {{domxref("SpeechSynthesis")}} object, which is the entry point into using <a href="/en-US/docs/Web/API/Web_Speech_API">Web Speech API</a> speech synthesis functionality.</dd>
<dt>{{domxref("Window.status")}}</dt>
<dd>Gets/sets the text in the statusbar at the bottom of the browser.</dd>
<dt>{{domxref("Window.statusbar")}} {{readOnlyInline}}</dt>
<dd>Returns the statusbar object, whose visibility can be toggled in the window.</dd>
<dt>{{domxref("Window.toolbar")}} {{readOnlyInline}}</dt>
<dd>Returns the toolbar object, whose visibility can be toggled in the window.</dd>
<dt>{{domxref("Window.top")}} {{readOnlyInline}}</dt>
<dd>Returns a reference to the topmost window in the window hierarchy. This property is read only.</dd>
<dt>{{domxref("Window.visualViewport")}} {{readOnlyInline}}</dt>
<dd>Returns a {{domxref("VisualViewport")}} object which represents the visual viewport for a given window.</dd>
<dt>{{domxref("Window.window")}} {{ReadOnlyInline}}</dt>
<dd>Returns a reference to the current window.</dd>
<dt><code>window[0]</code>,<code> window[1]</code>, etc.</dt>
<dd>Returns a reference to the <code>window</code> object in the frames. See {{domxref("Window.frames")}} for more details.</dd>
</dl>
<h3 id="Properties_implemented_from_elsewhere">Properties implemented from elsewhere</h3>
<dl>
<dt>{{domxref("WindowOrWorkerGlobalScope.caches")}} {{readOnlyinline}}</dt>
<dd>Returns the {{domxref("CacheStorage")}} object associated with the current context. This object enables functionality such as storing assets for offline use, and generating custom responses to requests.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.indexedDB")}} {{readonlyInline}}</dt>
<dd>Provides a mechanism for applications to asynchronously access capabilities of indexed databases; returns an {{domxref("IDBFactory")}} object.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.isSecureContext")}} {{readOnlyinline}}</dt>
<dd>Returns a boolean indicating whether the current context is secure (<code>true</code>) or not (<code>false</code>).</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.origin")}} {{readOnlyinline}}</dt>
<dd>Returns the global object's origin, serialized as a string. (This does not yet appear to be implemented in any browser.)</dd>
</dl>
<h2 id="Methods">Methods</h2>
<p><em>This interface inherits methods from the {{domxref("EventTarget")}} interface and implements methods from {{domxref("WindowOrWorkerGlobalScope")}} and {{domxref("EventTarget")}}.</em></p>
<dl>
<dt>{{domxref("Window.alert()")}}</dt>
<dd>Displays an alert dialog.</dd>
<dt>{{domxref("Window.back()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
<dd>Moves back one in the window history. This method is obsolete; you should instead use {{domxref("History.back", "window.history.back()")}}.</dd>
<dt>{{domxref("Window.blur()")}}</dt>
<dd>Sets focus away from the window.</dd>
<dt>{{domxref("Window.cancelAnimationFrame()")}} {{experimental_inline}}</dt>
<dd>Enables you to cancel a callback previously scheduled with {{domxref("Window.requestAnimationFrame")}}.</dd>
<dt>{{domxref("Window.cancelIdleCallback()")}} {{experimental_inline}}</dt>
<dd>Enables you to cancel a callback previously scheduled with {{domxref("Window.requestIdleCallback")}}.</dd>
<dt>{{domxref("Window.captureEvents()")}} {{Deprecated_inline}}</dt>
<dd>Registers the window to capture all events of the specified type.</dd>
<dt>{{domxref("Window.clearImmediate()")}}</dt>
<dd>Cancels the repeated execution set using <code>setImmediate</code>.</dd>
<dt>{{domxref("Window.close()")}}</dt>
<dd>Closes the current window.</dd>
<dt>{{domxref("Window.confirm()")}}</dt>
<dd>Displays a dialog with a message that the user needs to respond to.</dd>
<dt>{{domxref("Window.disableExternalCapture()")}} {{obsolete_inline(24)}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.dispatchEvent()")}}</dt>
<dd>Used to trigger an event.</dd>
<dt>{{domxref("Window.dump()")}} {{Non-standard_inline}}</dt>
<dd>Writes a message to the console.</dd>
<dt>{{domxref("Window.enableExternalCapture()")}} {{obsolete_inline(24)}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.find()")}}</dt>
<dd>Searches for a given string in a window.</dd>
<dt>{{domxref("Window.focus()")}}</dt>
<dd>Sets focus on the current window.</dd>
<dt>{{domxref("Window.forward()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
<dd>Moves the window one document forward in the history. This method is obsolete; you should instead use {{domxref("History.forward", "window.history.forward()")}}.</dd>
<dt>{{domxref("Window.getAttention()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
<dd>Flashes the application icon.</dd>
<dt>{{domxref("Window.getAttentionWithCycleCount()")}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.getComputedStyle()")}}</dt>
<dd>Gets computed style for the specified element. Computed style indicates the computed values of all CSS properties of the element.</dd>
<dt>{{domxref("Window.getDefaultComputedStyle()")}} {{Non-standard_inline}}</dt>
<dd>Gets default computed style for the specified element, ignoring author stylesheets.</dd>
<dt>{{domxref("Window.getSelection()")}}</dt>
<dd>Returns the selection object representing the selected item(s).</dd>
<dt>{{domxref("Window.home()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
<dd>Returns the browser to the home page.</dd>
<dt>{{domxref("Window.matchMedia()")}} {{gecko_minversion_inline("6.0")}}</dt>
<dd>Returns a {{domxref("MediaQueryList")}} object representing the specified media query string.</dd>
<dt>{{domxref("Window.maximize()")}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.minimize()")}} (top-level XUL windows only)</dt>
<dd>Minimizes the window.</dd>
<dt>{{domxref("Window.moveBy()")}}</dt>
<dd>Moves the current window by a specified amount.</dd>
<dt>{{domxref("Window.moveTo()")}}</dt>
<dd>Moves the window to the specified coordinates.</dd>
<dt>{{domxref("Window.open()")}}</dt>
<dd>Opens a new window.</dd>
<dt>{{domxref("Window.openDialog()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
<dd>Opens a new dialog window.</dd>
<dt>{{domxref("Window.postMessage()")}}</dt>
<dd>Provides a secure means for one window to send a string of data to another window, which need not be within the same domain as the first.</dd>
<dt>{{domxref("Window.print()")}}</dt>
<dd>Opens the Print Dialog to print the current document.</dd>
<dt>{{domxref("Window.prompt()")}}</dt>
<dd>Returns the text entered by the user in a prompt dialog.</dd>
<dt>{{domxref("Window.releaseEvents()")}} {{Non-standard_inline}} {{Deprecated_inline}}</dt>
<dd>Releases the window from trapping events of a specific type.</dd>
<dt>{{domxref("Window.requestAnimationFrame()")}} {{gecko_minversion_inline("2.0")}}</dt>
<dd>Tells the browser that an animation is in progress, requesting that the browser schedule a repaint of the window for the next animation frame.</dd>
<dt>{{domxref("Window.requestIdleCallback()")}} {{experimental_inline}}</dt>
<dd>Enables the scheduling of tasks during a browser's idle periods.</dd>
<dt>{{domxref("Window.resizeBy()")}}</dt>
<dd>Resizes the current window by a certain amount.</dd>
<dt>{{domxref("Window.resizeTo()")}}</dt>
<dd>Dynamically resizes window.</dd>
<dt>{{domxref("Window.restore()")}} {{Non-standard_inline}} {{obsolete_inline}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.routeEvent()")}} {{obsolete_inline(24)}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.scroll()")}}</dt>
<dd>Scrolls the window to a particular place in the document.</dd>
<dt>{{domxref("Window.scrollBy()")}}</dt>
<dd>Scrolls the document in the window by the given amount.</dd>
<dt>{{domxref("Window.scrollByLines()")}} {{Non-standard_inline}}</dt>
<dd>Scrolls the document by the given number of lines.</dd>
<dt>{{domxref("Window.scrollByPages()")}} {{Non-standard_inline}}</dt>
<dd>Scrolls the current document by the specified number of pages.</dd>
<dt>{{domxref("Window.scrollTo()")}}</dt>
<dd>Scrolls to a particular set of coordinates in the document.</dd>
<dt>{{domxref("Window.setCursor()")}} {{Non-standard_inline}} (top-level XUL windows only)</dt>
<dd>Changes the cursor for the current window</dd>
<dt>{{domxref("Window.setImmediate()")}}</dt>
<dd>Executes a function after the browser has finished other heavy tasks</dd>
<dt>{{domxref("Window.setResizable()")}} {{Non-standard_inline}}</dt>
<dd>Toggles a user's ability to resize a window.</dd>
<dt>{{domxref("Window.sizeToContent()")}} {{Non-standard_inline}}</dt>
<dd>Sizes the window according to its content.</dd>
<dt>{{domxref("Window.stop()")}}</dt>
<dd>This method stops window loading.</dd>
<dt>{{domxref("Window.updateCommands()")}} {{Non-standard_inline}}</dt>
<dd>Updates the state of commands of the current chrome window (UI).</dd>
</dl>
<h3 id="Methods_implemented_from_elsewhere">Methods implemented from elsewhere</h3>
<dl>
<dt>{{domxref("EventTarget.addEventListener()")}}</dt>
<dd>Register an event handler to a specific event type on the window.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.atob()")}}</dt>
<dd>Decodes a string of data which has been encoded using base-64 encoding.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.btoa()")}}</dt>
<dd>Creates a base-64 encoded ASCII string from a string of binary data.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.clearInterval()")}}</dt>
<dd>Cancels the repeated execution set using {{domxref("WindowOrWorkerGlobalScope.setInterval()")}}.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.clearTimeout()")}}</dt>
<dd>Cancels the delayed execution set using {{domxref("WindowOrWorkerGlobalScope.setTimeout()")}}.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.createImageBitmap()")}}</dt>
<dd>Accepts a variety of different image sources, and returns a {{domxref("Promise")}} which resolves to an {{domxref("ImageBitmap")}}. Optionally the source is cropped to the rectangle of pixels originating at <em>(sx, sy)</em> with width sw, and height sh.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.fetch()")}}</dt>
<dd>Starts the process of fetching a resource from the network.</dd>
<dt>{{domxref("EventTarget.removeEventListener")}}</dt>
<dd>Removes an event listener from the window.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.setInterval()")}}</dt>
<dd>Schedules a function to execute every time a given number of milliseconds elapses.</dd>
<dt>{{domxref("WindowOrWorkerGlobalScope.setTimeout()")}}</dt>
<dd>Schedules a function to execute in a given amount of time.</dd>
</dl>
<h3 id="Obsolete_methods">Obsolete methods</h3>
<dl>
<dt>{{domxref("Window.showModalDialog()")}} {{obsolete_inline}}</dt>
<dd>Displays a modal dialog. <strong>This method was removed completely in Chrome 43, and Firefox 55.</strong></dd>
</dl>
<h2 id="Event_handlers">Event handlers</h2>
<p>These are properties of the window object that can be set to establish event handlers for the various things that can happen in the window that might be of interest.</p>
<p><em>This interface inherits event handlers from the {{domxref("EventTarget")}} interface and implements event handlers from {{domxref("WindowEventHandlers")}}.</em></p>
<div class="note">
<p><strong>Note:</strong> Starting in {{Gecko("9.0")}}, you can now use the syntax <code>if ("onabort" in window)</code> to determine whether or not a given event handler property exists. This is because event handler interfaces have been updated to be proper web IDL interfaces. See <a href="/en-US/docs/DOM/DOM_event_handlers">DOM event handlers</a> for details.</p>
</div>
<dl>
<dt>{{domxref("Window.onappinstalled")}}</dt>
<dd>Called when the page is installed as a webapp. See {{event('appinstalled')}} event.</dd>
<dt>{{domxref("Window.onbeforeinstallprompt")}}</dt>
<dd>An event handler property dispatched before a user is prompted to save a web site to a home screen on mobile.</dd>
<dt>{{domxref("Window.ondevicelight")}}</dt>
<dd>An event handler property for any ambient light levels changes</dd>
<dt>{{domxref("Window.ondevicemotion")}} {{gecko_minversion_inline("6.0")}}</dt>
<dd>Called if accelerometer detects a change (For mobile devices)</dd>
<dt>{{domxref("Window.ondeviceorientation")}} {{gecko_minversion_inline("6.0")}}</dt>
<dd>Called when the orientation is changed (For mobile devices)</dd>
<dt>{{domxref("Window.ondeviceorientationabsolute")}} {{non-standard_inline}} Chrome only</dt>
<dd>An event handler property for any device orientation changes.</dd>
<dt>{{domxref("Window.ondeviceproximity")}}</dt>
<dd>An event handler property for device proximity event</dd>
<dt>{{domxref("Window.ongamepadconnected")}}</dt>
<dd>Represents an event handler that will run when a gamepad is connected (when the {{event('gamepadconnected')}} event fires).</dd>
<dt>{{domxref("Window.ongamepaddisconnected")}}</dt>
<dd>Represents an event handler that will run when a gamepad is disconnected (when the {{event('gamepaddisconnected')}} event fires).</dd>
<dt>{{domxref("Window.onmozbeforepaint")}} {{gecko_minversion_inline("2.0")}}</dt>
<dd>An event handler property for the <code>MozBeforePaint</code> event, which is sent before repainting the window if the event has been requested by a call to the {{domxref("Window.mozRequestAnimationFrame()")}} method.</dd>
<dt>{{domxref("Window.onpaint")}}</dt>
<dd>An event handler property for paint events on the window.</dd>
<dt>{{domxref("Window.onrejectionhandled")}} {{experimental_inline}}</dt>
<dd>An event handler for handled {{jsxref("Promise")}} rejection events.</dd>
<dt>{{domxref("Window.onuserproximity")}}</dt>
<dd>An event handler property for user proximity events.</dd>
<dt>{{domxref("Window.onvrdisplayconnect")}}</dt>
<dd>Represents an event handler that will run when a compatible VR device has been connected to the computer (when the {{event("vrdisplayconnected")}} event fires).</dd>
<dt>{{domxref("Window.onvrdisplaydisconnect")}}</dt>
<dd>Represents an event handler that will run when a compatible VR device has been disconnected from the computer (when the {{event("vrdisplaydisconnected")}} event fires).</dd>
<dt>{{domxref("Window.onvrdisplayactivate")}}</dt>
<dd>Represents an event handler that will run when a display is able to be presented to (when the {{event("vrdisplayactivate")}} event fires), for example if an HMD has been moved to bring it out of standby, or woken up by being put on.</dd>
<dt>{{domxref("Window.onvrdisplaydeactivate")}}</dt>
<dd>Represents an event handler that will run when a display can no longer be presented to (when the {{event("vrdisplaydeactivate")}} event fires), for example if an HMD has gone into standby or sleep mode due to a period of inactivity.</dd>
<dt>{{domxref("Window.onvrdisplayblur")}}</dt>
<dd>Represents an event handler that will run when presentation to a display has been paused for some reason by the browser, OS, or VR hardware (when the {{event("vrdisplayblur")}} event fires) — for example, while the user is interacting with a system menu or browser, to prevent tracking or loss of experience.</dd>
<dt>{{domxref("Window.onvrdisplayfocus")}}</dt>
<dd>Represents an event handler that will run when presentation to a display has resumed after being blurred (when the {{event("vrdisplayfocus")}} event fires).</dd>
<dt>{{domxref("Window.onvrdisplaypresentchange")}}</dt>
<dd>represents an event handler that will run when the presenting state of a VR device changes — i.e. goes from presenting to not presenting, or vice versa (when the {{event("vrdisplaypresentchange")}} event fires).</dd>
</dl>
<h3 id="Event_handlers_implemented_from_elsewhere">Event handlers implemented from elsewhere</h3>
<dl>
<dt>{{domxref("GlobalEventHandlers.onabort")}}</dt>
<dd>Called when the loading of a resource has been aborted, such as by a user canceling the load while it is still in progress</dd>
<dt>{{domxref("WindowEventHandlers.onafterprint")}}</dt>
<dd>Called when the print dialog box is closed. See {{event("afterprint")}} event.</dd>
<dt>{{domxref("WindowEventHandlers.onbeforeprint")}}</dt>
<dd>Called when the print dialog box is opened. See {{event("beforeprint")}} event.</dd>
<dt>{{domxref("WindowEventHandlers.onbeforeunload")}}</dt>
<dd>An event handler property for before-unload events on the window.</dd>
<dt>{{domxref("GlobalEventHandlers.onblur")}}</dt>
<dd>Called after the window loses focus, such as due to a popup.</dd>
<dt>{{domxref("GlobalEventHandlers.onchange")}}</dt>
<dd>An event handler property for change events on the window.</dd>
<dt>{{domxref("GlobalEventHandlers.onclick")}}</dt>
<dd>Called after the ANY mouse button is pressed & released</dd>
<dt>{{domxref("GlobalEventHandlers.ondblclick")}}</dt>
<dd>Called when a double click is made with ANY mouse button.</dd>
<dt>{{domxref("GlobalEventHandlers.onclose")}}</dt>
<dd>Called after the window is closed</dd>
<dt>{{domxref("GlobalEventHandlers.oncontextmenu")}}</dt>
<dd>Called when the RIGHT mouse button is pressed</dd>
<dt>{{domxref("GlobalEventHandlers.onerror")}}</dt>
<dd>Called when a resource fails to load OR when an error occurs at runtime. See {{event("error")}} event.</dd>
<dt>{{domxref("GlobalEventHandlers.onfocus")}}</dt>
<dd>Called after the window receives or regains focus. See {{event("focus")}} events.</dd>
<dt>{{domxref("WindowEventHandlers.onhashchange")}} {{gecko_minversion_inline("1.9.2")}}</dt>
<dd>An event handler property for {{event('hashchange')}} events on the window; called when the part of the URL after the hash mark ("#") changes.</dd>
<dt>{{domxref("GlobalEventHandlers.oninput")}}</dt>
<dd>Called when the value of an <input> element changes</dd>
<dt>{{domxref("GlobalEventHandlers.onkeydown")}}</dt>
<dd>Called when you begin pressing ANY key. See {{event("keydown")}} event.</dd>
<dt>{{domxref("GlobalEventHandlers.onkeypress")}}</dt>
<dd>Called when a key (except Shift, Fn, and CapsLock) is in pressed position. See {{event("keypress")}} event.</dd>
<dt>{{domxref("GlobalEventHandlers.onkeyup")}}</dt>
<dd>Called when you finish releasing ANY key. See {{event("keyup")}} event.</dd>
<dt>{{domxref("WindowEventHandlers.onlanguagechange")}}</dt>
<dd>An event handler property for {{event("languagechange")}} events on the window.</dd>
<dt>{{domxref("GlobalEventHandlers.onload")}}</dt>
<dd>Called after all resources and the DOM are fully loaded. WILL NOT get called when the page is loaded from cache, such as with back button.</dd>
<dt>{{domxref("WindowEventHandlers.onmessage")}}</dt>
<dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("message")}} event is raised.</dd>
<dt>{{domxref("GlobalEventHandlers.onmousedown")}}</dt>
<dd>Called when ANY mouse button is pressed.</dd>
<dt>{{domxref("GlobalEventHandlers.onmousemove")}}</dt>
<dd>Called continously when the mouse is moved inside the window.</dd>
<dt>{{domxref("GlobalEventHandlers.onmouseout")}}</dt>
<dd>Called when the pointer leaves the window.</dd>
<dt>{{domxref("GlobalEventHandlers.onmouseover")}}</dt>
<dd>Called when the pointer enters the window</dd>
<dt>{{domxref("GlobalEventHandlers.onmouseup")}}</dt>
<dd>Called when ANY mouse button is released</dd>
<dt>{{domxref("WindowEventHandlers.onoffline")}}</dt>
<dd>Called when network connection is lost. See {{event("offline")}} event.</dd>
<dt>{{domxref("WindowEventHandlers.ononline")}}</dt>
<dd>Called when network connection is established. See {{event("online")}} event.</dd>
<dt>{{domxref("WindowEventHandlers.onpagehide")}}</dt>
<dd>Called when the user navigates away from the page, before the onunload event. See {{event("pagehide")}} event.</dd>
<dt>{{domxref("WindowEventHandlers.onpageshow")}}</dt>
<dd>Called after all resources and the DOM are fully loaded. See {{event("pageshow")}} event.</dd>
<dt>{{domxref("WindowEventHandlers.onpopstate")}} {{gecko_minversion_inline("2.0")}}</dt>
<dd>Called when a back button is pressed.</dd>
<dt>{{domxref("GlobalEventHandlers.onreset")}}</dt>
<dd>Called when a form is reset</dd>
<dt>{{domxref("GlobalEventHandlers.onresize")}}</dt>
<dd>Called continuously as you are resizing the window.</dd>
<dt>{{domxref("GlobalEventHandlers.onscroll")}}</dt>
<dd>Called when the scroll bar is moved via ANY means. If the resource fully fits in the window, then this event cannot be invoked</dd>
<dt>{{domxref("GlobalEventHandlers.onwheel")}}</dt>
<dd>Called when the mouse wheel is rotated around any axis</dd>
<dt>{{domxref("GlobalEventHandlers.onselect")}}</dt>
<dd>Called after text in an input field is selected</dd>
<dt>{{domxref("GlobalEventHandlers.onselectionchange")}}</dt>
<dd>Is an {{domxref("EventHandler")}} representing the code to be called when the {{event("selectionchange")}} event is raised.</dd>
<dt>{{domxref("WindowEventHandlers.onstorage")}}</dt>
<dd>Called when there is a change in session storage or local storage. See {{event("storage")}} event</dd>
<dt>{{domxref("GlobalEventHandlers.onsubmit")}}</dt>
<dd>Called when a form is submitted</dd>
<dt>{{domxref("WindowEventHandlers.onunhandledrejection")}} {{experimental_inline}}</dt>
<dd>An event handler for unhandled {{jsxref("Promise")}} rejection events.</dd>
<dt>{{domxref("WindowEventHandlers.onunload")}}</dt>
<dd>Called when the user navigates away from the page.</dd>
</dl>
<h2 id="Constructors">Constructors</h2>
<p>See also the <a href="/en-US/docs/DOM/DOM_Reference" title="/en-US/docs/DOM/DOM_Reference">DOM Interfaces</a>.</p>
<dl>
<dt>{{domxref("DOMParser")}}</dt>
<dd><code>DOMParser</code> can parse XML or HTML source stored in a string into a DOM <a href="https://developer.mozilla.org/en-US/docs/DOM/document" title="document">Document</a>. <code>DOMParser</code> is specified in <a href="https://w3c.github.io/DOM-Parsing/" title="http://html5.org/specs/dom-parsing.html">DOM Parsing and Serialization</a>.</dd>
<dt>{{domxref("Window.GeckoActiveXObject")}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Image")}}</dt>
<dd>Used for creating an {{domxref("HTMLImageElement")}}.</dd>
<dt>{{domxref("Option")}}</dt>
<dd>Used for creating an {{domxref("HTMLOptionElement")}}</dd>
<dt>{{domxref("Window.QueryInterface")}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.StaticRange")}} {{experimental_inline}} {{readonlyinline}}</dt>
<dd>Returns a {{domxref('StaticRange.StaticRange','StaticRange()')}} constructor which creates a {{domxref('StaticRange')}} object.</dd>
<dt>{{domxref("Worker")}}</dt>
<dd>Used for creating a <a href="/en-US/docs/DOM/Using_web_workers">Web worker</a></dd>
<dt>{{domxref("Window.XMLSerializer")}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.XPCNativeWrapper")}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
<dt>{{domxref("Window.XPCSafeJSObjectWrapper")}}</dt>
<dd>{{todo("NeedsContents")}}</dd>
</dl>
<h2 id="Interfaces">Interfaces</h2>
<p>See <a href="/en-US/docs/DOM/DOM_Reference" title="/en-US/docs/DOM/DOM_Reference">DOM Reference</a></p>
<h2 id="Browser_compatibility">Browser compatibility</h2>
<p>{{Compat("api.Window")}}</p>
<h2 id="See_also">See also</h2>
<ul>
<li><a href="/en-US/docs/Working_with_windows_in_chrome_code">Working with windows in chrome code</a></li>
</ul>
|