This section describes features that apply most directly to Web browsers. Having said that, except where specified otherwise, the requirements defined in this section do apply to all user agents, whether they are Web browsers or not.
A browsing context is an environment in which
  Document objects are presented to the user.
A tab or window in a Web browser typically contains
  a browsing context, as does an iframe or frames in a
  frameset.
Each browsing context has a corresponding
  WindowProxy object.
A browsing context has a session
  history, which lists the Document objects that
  that browsing context has presented, is presenting, or
  will present. At any time, one Document in each
  browsing context is designated the active
  document. A Document's browsing
  context is that browsing context whose
  session history contains the Document, if
  any. (A Document created using an API such as createDocument()
  has no browsing context.)
Each Document is associated with a
  Window object. A browsing context's
  WindowProxy object forwards everything to the
  browsing context's active document's
  Window object.
In general, there is a 1-to-1 mapping from the
  Window object to the Document object.
  There are two exceptions. First, a Window can be reused
  for the presentation of a second Document in the same
  browsing context, such that the mapping is then 2-to-1.
  This occurs when a browsing context is navigated from the initial
  about:blank Document to another, with
  replacement enabled. Second, a Document
  can end up being reused for several Window objects when
  the document.open() method is
  used, such that the mapping is then 1-to-many.
A Document does not necessarily have a
  browsing context associated with it. In particular,
  data mining tools are likely to never instantiate browsing
  contexts.
A browsing context can have a creator browsing context, the browsing context that was responsible for its creation. If a browsing context has a parent browsing context, then that is its creator browsing context. Otherwise, if the browsing context has an opener browsing context, then that is its creator browsing context. Otherwise, the browsing context has no creator browsing context.
If a browsing context A has a
  creator browsing context, then the
  Document that was the active document of
  that creator browsing context at the time A was created is the creator
  Document.
When a browsing context is first created, it must be
  created with a single Document in its session history,
  whose address is
  about:blank, which is marked as being an HTML document, and whose character encoding is
  UTF-8. The Document must have a single child
  html node, which itself has a single child
  body node.
If the browsing context is created specifically to be immediately navigated, then that initial navigation will have replacement enabled.
The origin of the
  about:blank Document is set when the
  Document is created. If the new browsing
  context has a creator browsing context, then the
  origin of the about:blank
  Document is the origin of the
  creator Document. Otherwise, the
  origin of the about:blank
  Document is a globally unique identifier assigned when
  the new browsing context is created.
Certain elements (for example, iframe elements) can
  instantiate further browsing
  contexts. These are called nested browsing contexts. If a browsing context P has a Document D
  with an element E that nests another browsing
  context C inside it, then C
  is said to be nested
  through D, and E is
  said to be the browsing context container of C. If the browsing context container
  element E is in the Document D,
  then P is said to be the parent browsing
  context of C and C is
  said to be a child browsing context of P. Otherwise, the nested browsing
  context C has no parent browsing
  context.
A browsing context A is said to be an ancestor of a browsing context B if there exists a browsing context A' that is a child browsing context of A and that is itself an ancestor of B, or if there is a browsing context P that is a child browsing context of A and that is the parent browsing context of B.
A browsing context that is not a nested browsing context has no parent browsing context, and is the top-level browsing context of all the browsing contexts for which it is an ancestor browsing context.
The transitive closure of parent browsing contexts for a nested browsing context gives the list of ancestor browsing contexts.
The list of the descendant browsing contexts of a
  Document d is the (ordered) list
  returned by the following algorithm:
Let list be an empty list.
For each child browsing context of d that is nested through an element that is in the Document d, in the tree order of the elements
    nesting those browsing
    contexts, run these substeps:
Append that child browsing context to the list list.
Append the list of the descendant browsing contexts of the active document of that child browsing context to the list list.
Return the constructed list.
A Document is said to be fully active
  when it is the active document of its browsing
  context, and either its browsing context is a top-level
  browsing context, or it has a parent browsing
  context and the Document through which it is nested is itself fully
  active.
Because they are nested through an element, child browsing contexts are always tied to
  a specific Document in their parent browsing
  context. User agents must not allow the user to interact with
  child browsing contexts
  of elements that are in Documents that are not
  themselves fully active.
A nested browsing context can have a seamless
  browsing context flag set, if it is embedded through an
  iframe element with a seamless attribute.
A nested browsing context can in some
  cases be taken out of its parent browsing context (e.g.
  if an iframe element is removed from its
  Document). In such a situation, the nested
  browsing context has no parent browsing context,
  but it still has the same browsing context container
  and is still nested
  through that element's Document. Such a
  nested browsing context is not a
  top-level browsing context, and cannot contain
  Documents that are fully active.
  Furthermore, if a browsing context container (such as
  an iframe) is moved to another Document,
  then the parent browsing context of its nested
  browsing context will change.
topReturns the WindowProxy for the top-level browsing context.
parentReturns the WindowProxy for the parent browsing context.
frameElementReturns the Element for the browsing context container.
Returns null if there isn't one.
Throws a SecurityError exception in cross-origin situations.
The top IDL attribute on
  the Window object of a Document in a
  browsing context b must return the
  WindowProxy object of its top-level browsing
  context (which would be its own WindowProxy
  object if it was a top-level browsing context itself),
  if it has one, or its own WindowProxy object otherwise
  (e.g. if it was a detached nested browsing
  context).
The parent IDL
  attribute on the Window object of a
  Document in a browsing context b must return the WindowProxy object of
  the parent browsing context, if there is one (i.e. if
  b is a child browsing context), or
  the WindowProxy object of the browsing
  context b itself, otherwise (i.e. if it
  is a top-level browsing context or a detached
  nested browsing context).
The frameElement
  IDL attribute on the Window object of a
  Document d, on getting, must run
  the following algorithm:
If d is not a Document in a
   nested browsing context, return null and abort these
   steps.
If the browsing context container's
   Document does not have the same effective script origin as the
   entry script, then throw a SecurityError
   exception.
Otherwise, return the browsing context container for b.
It is possible to create new browsing contexts that are related to a top-level browsing context without being nested through an element. Such browsing contexts are called auxiliary browsing contexts. Auxiliary browsing contexts are always top-level browsing contexts.
An auxiliary browsing context has an opener browsing context, which is the browsing context from which the auxiliary browsing context was created.
The opener IDL
  attribute on the Window object, on getting, must return
  the WindowProxy object of the browsing
  context from which the current browsing context
  was created (its opener browsing context), if there is
  one, if it is still available, and if the current browsing
  context has not disowned its opener; otherwise, it
  must return null. On setting, if the new value is null then the
  current browsing context must disown its opener; if the new value is anything else
  then the user agent must ignore the new value.
User agents may support secondary browsing contexts, which are browsing contexts that form part of the user agent's interface, apart from the main content area.
A browsing context A is allowed to navigate a second browsing context B if one of the following conditions is true:
An element has a browsing context scope origin if its
  Document's browsing context is a
  top-level browsing context or if all of its
  Document's ancestor browsing contexts all have active documents whose
  origin are the same origin as the
  element's Document's origin. If an element
  has a browsing context scope origin, then its value is
  the origin of the element's Document.
Each browsing context is defined as having a list of one or more directly reachable browsing contexts. These are:
The transitive closure of all the browsing contexts that are directly reachable browsing contexts forms a unit of related browsing contexts.
Each unit of related browsing contexts is then
  further divided into the smallest number of groups such that every
  member of each group has an active document with an
  effective script origin that, through appropriate
  manipulation of the document.domain attribute, could
  be made to be the same as other members of the group, but could not
  be made the same as members of any other group. Each such group is a
  unit of related similar-origin browsing contexts.
Each unit of related similar-origin browsing contexts can have an entry script which is used to obtain, amongst other things, the script's base URL to resolve relative URLs used in scripts running in that unit of related similar-origin browsing contexts. Initially, there is no entry script. It is changed by the jump to a code entry-point algorithm.
Each unit of related similar-origin browsing
  contexts also has a running mutation observers
  flag, which must initially be false. It is used to prevent reentrant
  invocation of the algorithm to invoke MutationObserver
  objects. For the purposes of MutationObserver
  objects, each unit of related similar-origin browsing
  contexts is a distinct scripting environment.
There is also at most one event loop per unit of related similar-origin browsing contexts (though several units of related similar-origin browsing contexts can have a shared event loop).
Browsing contexts can have a browsing context name. By default, a browsing context has no name (its name is not set).
A valid browsing context name is any string with at least one character that does not start with a U+005F LOW LINE character. (Names starting with an underscore are reserved for special keywords.)
A valid browsing context name or keyword is any string
  that is either a valid browsing context name or that is
  an ASCII case-insensitive match for one of: _blank, _self, _parent, or _top.
These values have different meanings based on whether the page is sandboxed or not, as summarized in the following (non-normative) table. In this table, "current" means the browsing context that the link or script is in, "parent" means the parent browsing context of the one the link or script is in, "master" means the nearest ancestor browsing context of the one the link or script is in that is not itself in a seamless iframe, "top" means the top-level browsing context of the one the link or script is in, "new" means a new top-level browsing context or auxiliary browsing context is to be created, subject to various user preferences and user agent policies, "maybe new" means the same as "new" but the requirements for those cases encourage user agents to treat it more like "none", and "none" means that by default nothing will happen.
| Keyword | Ordinary effect | Effect in an iframewith... | ||||
|---|---|---|---|---|---|---|
| seamless="" | sandbox="" | sandbox="" seamless="" | sandbox="allow-top-navigation" | sandbox="allow-top-navigation" seamless="" | ||
| none specified, for links and form submissions | current | master | current | master | current | master | 
| none specified, for window.open() | new | new | maybe new† | maybe new† | maybe new† | maybe new† | 
| empty string | current | master | current | master | current | master | 
| _blank | new | new | maybe new | maybe new | maybe new | maybe new | 
| _self | current | current | current | current | current | current | 
| _parentif there isn't a parent | current | current | current | current | current | current | 
| _parentif parent is also top | parent/top | parent/top | none | none | parent/top | parent/top | 
| _parentif there is one and it's not top | parent | parent | none | none | none | none | 
| _topif top is current | current | current | current | current | current | current | 
| _topif top is not current | top | top | none | none | top | top | 
| name that doesn't exist | new | new | maybe new | maybe new | maybe new | maybe new | 
| name that exists and is a descendant | specified descendant | specified descendant | specified descendant | specified descendant | specified descendant | specified descendant | 
| name that exists and is current | current | current | current | current | current | current | 
| name that exists and is an ancestor that is top | specified ancestor | specified ancestor | none | none | specified ancestor/top | specified ancestor/top | 
| name that exists and is an ancestor that is not top | specified ancestor | specified ancestor | none | none | none | none | 
† This case is only possible if the sandbox attribute also allows
  scripts.
An algorithm is allowed to show a pop-up if, in the task in which the algorithm is running, either:
click event was
   trusted, orclick event is being handled.The rules for choosing a browsing context given a browsing context name are as follows. The rules assume that they are being applied in the context of a browsing context.
If the given browsing context name is the empty string or _self, then the chosen browsing context must be
    the current one.
If the given browsing context name is _self, then this is an explicit
    self-navigation override, which overrides the behavior of
    the seamless browsing context flag set by the seamless attribute on
    iframe elements.
If the given browsing context name is _parent, then the chosen browsing context must be
   the parent browsing context of the current
   one, unless there isn't one, in which case the chosen browsing
   context must be the current browsing context.
If the given browsing context name is _top, then the chosen browsing context must be the
   top-level browsing context of the current one, if
   there is one, or else the current browsing context.
If the given browsing context name is not _blank and there exists a browsing context whose
    name is the same as the
    given browsing context name, and the current browsing context is
    allowed to navigate that browsing context, and the
    user agent determines that the two browsing contexts are related
    enough that it is ok if they reach each other, then that browsing
    context must be the chosen one. If there are multiple matching
    browsing contexts, the user agent should select one in some
    arbitrary consistent manner, such as the most recently opened,
    most recently focused, or more closely related.
If the browsing context is chosen by this step to be the current browsing context, then this is also an explicit self-navigation override.
Otherwise, a new browsing context is being requested, and what happens depends on the user agent's configuration and/or abilities — it is determined by the rules given for the first applicable option from the following list:
The user agent may offer to create a new top-level browsing context or reuse an existing top-level browsing context. If the user picks one of those options, then the designated browsing context must be the chosen one (the browsing context's name isn't set to the given browsing context name). The default behaviour (if the user agent doesn't offer the option to the user, or if the user declines to allow a browsing context to be used) there must not be a chosen browsing context.
noreferrer keywordA new top-level browsing context must be
     created. If the given browsing context name is not _blank, then the new top-level browsing context's
     name must be the given browsing context name (otherwise, it has
     no name). The chosen browsing context must be this new browsing
     context.
If it is immediately navigated, then the navigation will be done with replacement enabled.
noreferrer keyword doesn't
     applyA new auxiliary browsing context must be
     created, with the opener browsing context being the
     current one. If the given browsing context name is not _blank, then the new auxiliary browsing context's
     name must be the given browsing context name (otherwise, it has
     no name). The chosen browsing context must be this new browsing
     context.
If it is immediately navigated, then the navigation will be done with replacement enabled.
The chosen browsing context is the current browsing context.
There must not be a chosen browsing context.
User agent implementors are encouraged to provide a way for users to configure the user agent to always reuse the current browsing context.
Window object[ReplaceableNamedProperties]
interface Window : EventTarget {
  // the current browsing context
  [Unforgeable] readonly attribute WindowProxy window;
  [Replaceable] readonly attribute WindowProxy self;
  [Unforgeable] readonly attribute Document document;
           attribute DOMString name; 
  [PutForwards=href, Unforgeable] readonly attribute Location location;
  readonly attribute History history;
  boolean find(optional DOMString aString, optional boolean aCaseSensitive, optional boolean aBackwards, optional boolean aWrapAround, optional boolean aWholeWord, optional boolean aSearchInFrames, optional boolean aShowDialog);
  [Replaceable] readonly attribute BarProp locationbar;
  [Replaceable] readonly attribute BarProp menubar;
  [Replaceable] readonly attribute BarProp personalbar;
  [Replaceable] readonly attribute BarProp scrollbars;
  [Replaceable] readonly attribute BarProp statusbar;
  [Replaceable] readonly attribute BarProp toolbar;
           attribute DOMString status;
  void close();
  void stop();
  void focus();
  void blur();
  // other browsing contexts
  [Replaceable] readonly attribute WindowProxy frames;
  [Replaceable] readonly attribute unsigned long length;
  [Unforgeable] readonly attribute WindowProxy top;
           attribute WindowProxy? opener;
  readonly attribute WindowProxy parent;
  readonly attribute Element? frameElement;
  WindowProxy open(optional DOMString url, optional DOMString target, optional DOMString features, optional boolean replace);
  getter WindowProxy (unsigned long index);
  getter object (DOMString name);
  // the user agent
  readonly attribute Navigator navigator; 
  readonly attribute External external;
  readonly attribute ApplicationCache applicationCache;
  // user prompts
  void alert(DOMString message);
  boolean confirm(DOMString message);
  DOMString? prompt(DOMString message, optional DOMString default);
  void print();
  any showModalDialog(DOMString url, optional any argument);
  // cross-document messaging
  void postMessage(any message, DOMString targetOrigin, optional sequence<Transferable> transfer);
  // event handler IDL attributes
  [TreatNonCallableAsNull] attribute Function? onabort;
  [TreatNonCallableAsNull] attribute Function? onafterprint;
  [TreatNonCallableAsNull] attribute Function? onbeforeprint;
  [TreatNonCallableAsNull] attribute Function? onbeforeunload;
  [TreatNonCallableAsNull] attribute Function? onblur;
  [TreatNonCallableAsNull] attribute Function? oncanplay;
  [TreatNonCallableAsNull] attribute Function? oncanplaythrough;
  [TreatNonCallableAsNull] attribute Function? onchange;
  [TreatNonCallableAsNull] attribute Function? onclick;
  [TreatNonCallableAsNull] attribute Function? oncontextmenu;
  [TreatNonCallableAsNull] attribute Function? oncuechange;
  [TreatNonCallableAsNull] attribute Function? ondblclick;
  [TreatNonCallableAsNull] attribute Function? ondrag;
  [TreatNonCallableAsNull] attribute Function? ondragend;
  [TreatNonCallableAsNull] attribute Function? ondragenter;
  [TreatNonCallableAsNull] attribute Function? ondragleave;
  [TreatNonCallableAsNull] attribute Function? ondragover;
  [TreatNonCallableAsNull] attribute Function? ondragstart;
  [TreatNonCallableAsNull] attribute Function? ondrop;
  [TreatNonCallableAsNull] attribute Function? ondurationchange;
  [TreatNonCallableAsNull] attribute Function? onemptied;
  [TreatNonCallableAsNull] attribute Function? onended;
  [TreatNonCallableAsNull] attribute Function? onerror;
  [TreatNonCallableAsNull] attribute Function? onfocus;
  [TreatNonCallableAsNull] attribute Function? onhashchange;
  [TreatNonCallableAsNull] attribute Function? oninput;
  [TreatNonCallableAsNull] attribute Function? oninvalid;
  [TreatNonCallableAsNull] attribute Function? onkeydown;
  [TreatNonCallableAsNull] attribute Function? onkeypress;
  [TreatNonCallableAsNull] attribute Function? onkeyup;
  [TreatNonCallableAsNull] attribute Function? onload;
  [TreatNonCallableAsNull] attribute Function? onloadeddata;
  [TreatNonCallableAsNull] attribute Function? onloadedmetadata;
  [TreatNonCallableAsNull] attribute Function? onloadstart;
  [TreatNonCallableAsNull] attribute Function? onmessage;
  [TreatNonCallableAsNull] attribute Function? onmousedown;
  [TreatNonCallableAsNull] attribute Function? onmousemove;
  [TreatNonCallableAsNull] attribute Function? onmouseout;
  [TreatNonCallableAsNull] attribute Function? onmouseover;
  [TreatNonCallableAsNull] attribute Function? onmouseup;
  [TreatNonCallableAsNull] attribute Function? onmousewheel;
  [TreatNonCallableAsNull] attribute Function? onoffline;
  [TreatNonCallableAsNull] attribute Function? ononline;
  [TreatNonCallableAsNull] attribute Function? onpause;
  [TreatNonCallableAsNull] attribute Function? onplay;
  [TreatNonCallableAsNull] attribute Function? onplaying;
  [TreatNonCallableAsNull] attribute Function? onpagehide;
  [TreatNonCallableAsNull] attribute Function? onpageshow;
  [TreatNonCallableAsNull] attribute Function? onpopstate;
  [TreatNonCallableAsNull] attribute Function? onprogress;
  [TreatNonCallableAsNull] attribute Function? onratechange;
  [TreatNonCallableAsNull] attribute Function? onreset;
  [TreatNonCallableAsNull] attribute Function? onresize;
  [TreatNonCallableAsNull] attribute Function? onscroll;
  [TreatNonCallableAsNull] attribute Function? onseeked;
  [TreatNonCallableAsNull] attribute Function? onseeking;
  [TreatNonCallableAsNull] attribute Function? onselect;
  [TreatNonCallableAsNull] attribute Function? onshow;
  [TreatNonCallableAsNull] attribute Function? onstalled;
  [TreatNonCallableAsNull] attribute Function? onstorage;
  [TreatNonCallableAsNull] attribute Function? onsubmit;
  [TreatNonCallableAsNull] attribute Function? onsuspend;
  [TreatNonCallableAsNull] attribute Function? ontimeupdate;
  [TreatNonCallableAsNull] attribute Function? onunload;
  [TreatNonCallableAsNull] attribute Function? onvolumechange;
  [TreatNonCallableAsNull] attribute Function? onwaiting;
};
  windowframesselfThese attributes all return window.
documentReturns the active document.
defaultViewReturns the Window object of the active document.
The Window interface must not exist if the
  interface's relevant namespace object is not a
  Window object. [WEBIDL]
The window, frames, and self IDL attributes must all
  return the Window object's browsing
  context's WindowProxy object.
The document IDL
  attribute must return the Document object of the
  Window object's Document's browsing
  context's active document.
The defaultView IDL
  attribute of the Document interface must return the
  Document's browsing context's
  WindowProxy object, if there is one, or null
  otherwise.
For historical reasons, Window objects must also
  have a writable, configurable, non-enumerable property named
  HTMLDocument whose value is the
  Document interface object.
User agents must throw a
  SecurityError exception whenever any properties of a
  Window object are accessed by scripts whose
  effective script origin is not the same as the
  Window object's Document's effective
  script origin, with the following exceptions:
location attribute
   postMessage() method
   frames attribute
   When a script whose effective script origin is not
  the same as the Window object's Document's
  effective script origin attempts to access that
  Window object's methods or attributes, the user agent
  must act as if any changes to the Window object's
  properties, getters, setters, etc, were not present.
For members that return objects (including function objects),
  each distinct effective script origin that is not the
  same as the Window object's Document's
  effective script origin must be provided with a
  separate set of objects. These objects must have the prototype chain
  appropriate for the script for which the objects are created (not
  those that would be appropriate for scripts whose script's
  global object is the Window object in
  question).
For instance, if two frames containing Documents
   from different origins access the same
   Window object's postMessage() method, they
   will get distinct objects that are not equal.
open( [ url [, target [, features [, replace ] ] ] ] )Opens a window to show url (defaults to
    about:blank), and returns it. The target argument gives the name of the new
    window. If a window exists with that name already, it is
    reused. The replace attribute, if true, means
    that whatever page is currently open in that window will be
    removed from the window's session history. The features argument is ignored.
name [ = value ]Returns the name of the window.
Can be set, to change the name.
close()Closes the window.
stop()Cancels the document load.
The open() method on
  Window objects provides a mechanism for navigating an existing browsing
  context or opening and navigating an auxiliary browsing
  context.
The method has four arguments, though they are all optional.
The first argument, url, must be a
  valid non-empty URL for a page to load in the browsing
  context. If no arguments are provided, or if the first argument is
  the empty string, then the url argument defaults
  to "about:blank". The argument must be resolved to an absolute
  URL (or an error), relative to the entry
  script's base URL,
  when the method is invoked.
The second argument, target, specifies the
  name of the browsing
  context that is to be navigated. It must be a valid browsing
  context name or keyword. If fewer than two arguments are
  provided, then the target argument defaults to the
  value "_blank".
The third argument, features, has no defined effect and is mentioned for historical reasons only. User agents may interpret this argument as instructions to set the size and position of the browsing context, but are encouraged to instead ignore the argument entirely.
The fourth argument, replace, specifies whether or not the new page will replace the page currently loaded in the browsing context, when target identifies an existing browsing context (as opposed to leaving the current page in the browsing context's session history). When three or fewer arguments are provided, replace defaults to false.
When the method is invoked, the user agent must first select a browsing context to navigate by applying the rules for choosing a browsing context given a browsing context name using the target argument as the name and the browsing context of the script as the context in which the algorithm is executed, unless the user has indicated a preference, in which case the browsing context to navigate may instead be the one indicated by the user.
For example, suppose there is a user agent that
  supports control-clicking a link to open it in a new tab. If a user
  clicks in that user agent on an element whose onclick handler uses the window.open() API to open a page in an
  iframe, but, while doing so, holds the control key down, the user
  agent could override the selection of the target browsing context to
  instead target a new tab.
If the method is not allowed to show a pop-up and
  applying the rules for choosing a browsing context given a
  browsing context name using the target
  argument, would result in there not being a chosen browsing context,
  then throw an InvalidAccessError exception and abort
  these steps.
Otherwise, if url is not
  "about:blank", the user agent must
  navigate the selected
  browsing context to the absolute URL (or
  error) obtained from resolving
  url earlier. If the replace
  is true or if the browsing context was just created as
  part of the rules for choosing a browsing context given a
  browsing context name, then replacement must be enabled. The navigation must be
  done with the browsing
  context of the entry script as the source
  browsing context.
If url is
  "about:blank", the user agent must instead queue
  a task to fire a simple event named load at the selected browsing
  context's Window object, but with its target set to the selected
  browsing context's Window object's
  Document object (and the currentTarget set to the
  Window object).
The method must return the WindowProxy object of the
  browsing context that was navigated, or null if no
  browsing context was navigated.
The name attribute of
  the Window object must, on getting, return the current
  name of the browsing context, and, on setting, set the
  name of the browsing context to the new value.
The name gets reset when the browsing context is navigated to another domain.
The close()
  method on Window objects should, if the corresponding
  browsing context A is an
  auxiliary browsing context that was created by a script
  (as opposed to by an action of the user), and if the browsing context of the
  script that invokes the method
  is allowed to navigate the browsing
  context A, close the browsing
  context A (and may discard it too).
The stop() method
  on Window objects should, if there is an existing
  attempt to navigate the browsing context
  and that attempt is not currently running the unload a
  document algorithm, cancel that navigation and any associated instances of
  the fetch algorithm. Otherwise, it must
  do nothing.
lengthReturns the number of child browsing contexts.
Returns the indicated child browsing context.
The length IDL
  attribute on the Window interface must return the
  number of child browsing
  contexts that are nested through elements that are in the Document that is the
  active document of that Window object, if
  that Window's browsing context shares the
  same event loop as the script's browsing
  context of the entry script accessing the IDL
  attribute; otherwise, it must return zero.
The supported property indices on the
  Window object at any instant are the numbers in the
  range 0 .. n-1, where n is the number returned by the length IDL attribute. If n is zero then there are no supported property
  indices.
To determine the value of an indexed
  property index of a Window
  object, the user agent must return the WindowProxy
  object of the indexth child browsing
  context of the Document that is nested through
  an element that is in the
  Document, sorted in the tree order
  of the elements nesting those browsing contexts.
These properties are the dynamic nested browsing context properties.
Window objectReturns the indicated element or collection of elements.
The Window interface supports named properties. The supported
  property names at any moment consist of:
name content attribute
   for all a, applet, area,
   embed, form, frame,
   frameset, iframe, img, and
   object elements in the active document
   that have a name content attribute, andid content
   attribute of any HTML element in
   the active document with an id content attribute.It is possible that this will change. Browser vendors are considering limiting this behaviour to quirks mode. Read more...
To determine the value of a named property name when the
  Window object is indexed for property retrieval,
  the user agent must return the value obtained using the following
  steps:
Let elements be the list of named elements with the name name in the active document.
There will be at least one such element, by definition.
If elements contains an iframe
    element, then return the WindowProxy object of the
    nested browsing context represented by the first such
    iframe element in tree order, and abort
    these steps.
Otherwise, if elements has only one element, return that element and abort these steps.
Otherwise return an HTMLCollection rooted at the
    Document node, whose filter matches only named elements with
    the name name.
Named elements with the name name, for the purposes of the above algorithm, are those that are either:
A browsing context has a strong reference to each of
  its Documents and its WindowProxy object,
  and the user agent itself has a strong reference to its top-level browsing
  contexts.
A Document has a strong reference to its
  Window object.
A Window object has a strong reference to its
  Document object through its document attribute.  Thus, references
  from other scripts to either of those objects will keep both
  alive. Similarly, both Document and Window
  objects have implied strong
  references to the WindowProxy object.
Each script has a strong reference to its browsing context and its document.
When a browsing context is to discard a
  Document, the user agent must run the following
  steps:
Set the Document's salvageable state to
   false.
Run any unloading document cleanup steps for
   the Document that are defined by this specification
   and other applicable specifications.
Remove any tasks
   associated with the Document in any task
   source, without running those tasks.
Discard
   all the child browsing
   contexts of the Document.
Lose the strong reference from the Document's
   browsing context to the
   Document.
Whenever a Document object is discarded, it is also removed from
  the list of the worker's Documents of each
  worker whose list contains that Document.
When a browsing context is
  discarded, the strong reference from the user agent itself to
  the browsing context must be severed, and all the
  Document objects for all the entries in the
  browsing context's session history must be discarded as well.
User agents may discard top-level browsing contexts at any time (typically,
  in response to user requests, e.g. when a user closes a window
  containing one or more top-level browsing contexts). Other browsing contexts must be discarded
  once their WindowProxy object is eligible for garbage
  collection.
To allow Web pages to integrate with Web browsers, certain Web browser interface elements are exposed in a limited way to scripts in Web pages.
Each interface element is represented by a BarProp
  object:
interface BarProp {
           attribute boolean visible;
};
  locationbar . visibleReturns true if the location bar is visible; otherwise, returns false.
menubar . visibleReturns true if the menu bar is visible; otherwise, returns false.
personalbar . visibleReturns true if the personal bar is visible; otherwise, returns false.
scrollbars . visibleReturns true if the scroll bars are visible; otherwise, returns false.
statusbar . visibleReturns true if the status bar is visible; otherwise, returns false.
toolbar . visibleReturns true if the toolbar is visible; otherwise, returns false.
The visible attribute, on getting, must return either true or a value determined by the user agent to most accurately represent the visibility state of the user interface element that the object represents, as described below. On setting, the new value must be discarded.
The following BarProp objects exist for each
  Document object in a browsing
  context. Some of the user interface elements represented by
  these objects might have no equivalent in some user agents; for
  those user agents, except when otherwise specified, the object must
  act as if it was present and visible (i.e. its visible attribute must return
  true).
BarProp objectBarProp objectBarProp objectBarProp objectBarProp objectvisible
   attribute may return false).BarProp objectvisible
   attribute may return false).The locationbar
  attribute must return the location bar BarProp
  object.
The menubar
  attribute must return the menu bar BarProp
  object.
The personalbar
  attribute must return the personal bar BarProp
  object.
The scrollbars
  attribute must return the scrollbar BarProp
  object.
The statusbar attribute
  must return the status bar BarProp
  object.
The toolbar
  attribute must return the toolbar BarProp
  object.
For historical reasons, the status attribute on the
  Window object must return an empty string on getting,
  and do nothing on setting.
WindowProxy objectAs mentioned earlier, each browsing context has a
  WindowProxy object. This object is unusual
  in that all operations that would be performed on it must be
  performed on the Window object of the browsing
  context's active document instead. It is thus
  indistinguishable from that Window object in every way
  until the browsing context is navigated.
There is no WindowProxy interface object.
The WindowProxy object allows scripts
  to act as if each browsing context had a single
  Window object, while still keeping separate
  Window objects for each Document.
In the following example, the variable x is
   set to the WindowProxy object returned by the window accessor on the global object. All
   of the expressions following the assignment return true, because in
   every respect, the WindowProxy object acts like the
   underlying Window object.
var x = window; x instanceof Window; // true x === this; // true