Status: Last call for comments. ISSUE-94 (webcoresplit) blocks progress to Last Call
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.
Status: Last call for comments
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 frame
s 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.
Each Document
has a collection of one or more views.
A view is a user agent interface tied to a particular
media used for the presentation of a particular
Document
object in some media. A view may be
interactive. Each view is represented by an
AbstractView
object. [DOMVIEWS]
The main view through which a user primarily
interacts with a user agent is the default view. The
AbstractView
object that represents this view must also implement the Window
interface,
and is referred to as the Document
's
Window
object. WindowProxy
objects forward
everything to the active document's default
view's Window
object.
The defaultView
attribute on the Document
object's
DocumentView
interface must return the browsing
context's WindowProxy
object, not the actual
AbstractView
object of the default
view. [DOMVIEWS]
The document
attribute of an AbstractView
object representing a
view gives the view's corresponding
Document
object. [DOMVIEWS]
In general, there is a 1-to-1 mapping from the
Window
object to the Document
object. In
one particular case, a set of views 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.
Events that use the UIEvent
interface are related to
a specific view (the view in which the event happened);
when that view is the default view, the
event object's view
attribute's must return
the WindowProxy
object of the browsing
context of that view, not the actual
AbstractView
object of the default
view. [DOMEVENTS]
A typical Web browser has one obvious
view per Document
: the browser's window
(screen media). This is typically the default view. If
a page is printed, however, a second view becomes evident, that of
the print media. The two views always share the same underlying
Document
object, but they have a different presentation
of that object. A speech browser might have a different
default view, using the speech media.
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.
Status: Last call for comments
Certain elements (for example, iframe
elements) can
instantiate further browsing
contexts. These are called nested browsing contexts. If a browsing context P has an element E in one of its
Document
s D that nests another
browsing context C inside it, then P is said to be the parent browsing
context of C, C is
said to be a child browsing context of P, C is said to be nested through D, and E is said to be the
browsing context container of C.
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.
The browsing context with no parent browsing context is the top-level browsing context of all the browsing contexts nested within it (either directly or indirectly through other nested browsing contexts).
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 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 of
the elements nesting those browsing
contexts, append to the list list the
list of the descendant browsing contexts of the
active document of that child browsing
context.
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 the Document
through which that
browsing context 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 Document
s 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.
Status: Last call for comments
top
Returns the WindowProxy
for the top-level browsing context.
parent
Returns the WindowProxy
for the parent browsing context.
frameElement
Returns the Element
for the browsing context container.
Returns null if there isn't one.
Throws a SECURITY_ERR
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).
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).
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
child browsing context, return null and abort these
steps.
If the parent browsing context's active
document does not have the same effective script origin as the
entry script, then throw a SECURITY_ERR
exception.
Otherwise, return the browsing context container for b.
Status: Last call for comments
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, and it has a furthest ancestor browsing context, which is the top-level browsing context of the opener browsing context when the auxiliary browsing context was created.
Status: Last call for comments
The opener
IDL
attribute on the Window
object 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 and it
is still available.
Status: Last call for comments
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.
Status: Last call for comments
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
.
Status: Last call for comments
Each browsing context is defined as having a list of zero 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 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 a 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.
There is at most one event loop per unit of related similar-origin browsing contexts.
Status: Last call for comments
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
.
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 _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
most top-level browsing context of the current
one.
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.
Otherwise, a new browsing context is being requested, and what happens depends on the user agent's configuration and/or abilities:
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). Otherwise (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
objectStatus: Last call for comments
[OverrideBuiltins, ReplaceableNamedProperties] interface Window { // the current browsing context readonly attribute WindowProxy window; readonly attribute WindowProxy self; attribute DOMString name; [PutForwards=href] readonly attribute Location location; readonly attribute History history; readonly attribute UndoManager undoManager; Selection getSelection(); [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; void close(); void focus(); void blur(); // other browsing contexts [Replaceable] readonly attribute WindowProxy frames; [Replaceable] readonly attribute unsigned long length; readonly attribute WindowProxy top; [Replaceable] readonly attribute WindowProxy opener; readonly attribute WindowProxy parent; readonly attribute Element frameElement; WindowProxy open(in optional DOMString url, in optional DOMString target, in optional DOMString features, in optional DOMString replace); getter WindowProxy (in unsigned long index); getter WindowProxy (in DOMString name); // the user agent readonly attribute Navigator navigator; readonly attribute ApplicationCache applicationCache; // user prompts void alert(in DOMString message); boolean confirm(in DOMString message); DOMString prompt(in DOMString message, in optional DOMString default); void print(); any showModalDialog(in DOMString url, in optional any argument); // event handler IDL attributes attribute Function onabort; attribute Function onafterprint; attribute Function onbeforeprint; attribute Function onbeforeunload; attribute Function onblur; attribute Function oncanplay; attribute Function oncanplaythrough; attribute Function onchange; attribute Function onclick; attribute Function oncontextmenu; attribute Function ondblclick; attribute Function ondrag; attribute Function ondragend; attribute Function ondragenter; attribute Function ondragleave; attribute Function ondragover; attribute Function ondragstart; attribute Function ondrop; attribute Function ondurationchange; attribute Function onemptied; attribute Function onended; attribute Function onerror; attribute Function onfocus; attribute Function onformchange; attribute Function onforminput; attribute Function onhashchange; attribute Function oninput; attribute Function oninvalid; attribute Function onkeydown; attribute Function onkeypress; attribute Function onkeyup; attribute Function onload; attribute Function onloadeddata; attribute Function onloadedmetadata; attribute Function onloadstart; attribute Function onmessage; attribute Function onmousedown; attribute Function onmousemove; attribute Function onmouseout; attribute Function onmouseover; attribute Function onmouseup; attribute Function onmousewheel; attribute Function onoffline; attribute Function ononline; attribute Function onpause; attribute Function onplay; attribute Function onplaying; attribute Function onpagehide; attribute Function onpageshow; attribute Function onpopstate; attribute Function onprogress; attribute Function onratechange; attribute Function onreadystatechange; attribute Function onredo; attribute Function onresize; attribute Function onscroll; attribute Function onseeked; attribute Function onseeking; attribute Function onselect; attribute Function onshow; attribute Function onstalled; attribute Function onstorage; attribute Function onsubmit; attribute Function onsuspend; attribute Function ontimeupdate; attribute Function onundo; attribute Function onunload; attribute Function onvolumechange; attribute Function onwaiting; }; Window implements EventTarget;
window
frames
self
These attributes all return window.
The window
, frames
, and self
IDL attributes must all
return the Window
object's browsing
context's WindowProxy
object.
Status: Last call for comments
User agents must raise a SECURITY_ERR
exception
whenever any of the members 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
object
postMessage()
method with two arguments
postMessage()
method with three arguments
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).
Status: Last call for comments
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.
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 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 name argument defaults to the
value "_blank
".
The third argument, features, has no effect and is supported for historical reasons only.
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.
Then, 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, then replacement must be enabled; otherwise, it must not be enabled unless the browsing context was just created as part of the rules for choosing a browsing context given a browsing context name. The navigation must be done with the browsing context of the entry script as the source browsing context.
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).
Status: Last call for comments
length
Returns 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 indices of the supported indexed properties 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 indexed
properties.
When a Window
object is indexed to retrieve an indexed
property index, the value returned must be
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
objectStatus: Last call for comments
Returns the indicated child browsing context.
The Window
interface supports named properties. The names of the
supported named properties at any moment consist of:
name
content attribute
for all a
, applet
, area
,
embed
, frame
, frameset
,
form
, iframe
, img
, and
object
elements in the active document
that have a name
content attribute, and,id
content
attribute of any HTML element in
the active document with an id
content attribute.When the Window
object is indexed for property retrieval using a name name, then 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:
Status: Last call for comments
A browsing context has a strong reference to each of
its Document
s 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 each of its
views and their AbstractView
objects.
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 or
any other relevant 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
.
The browsing context's default
view's Window
object has a strong reference to its
Document
object through the document
attribute of the
AbstractView
interface. Thus, references from other
scripts to either of those objects will keep both alive. [DOMVIEWS]
Whenever a Document
object is discarded, it is also removed from
the list of the worker's Document
s 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.
Status: Last call for comments
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
. visible
Returns true if the location bar is visible; otherwise, returns false.
menubar
. visible
Returns true if the menu bar is visible; otherwise, returns false.
personalbar
. visible
Returns true if the personal bar is visible; otherwise, returns false.
scrollbars
. visible
Returns true if the scroll bars are visible; otherwise, returns false.
statusbar
. visible
Returns true if the status bar is visible; otherwise, returns false.
toolbar
. visible
Returns 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.
WindowProxy
objectStatus: Last call for comments
As 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
Status: Last call for comments
The origin of a resource and the effective script origin of a resource are both either opaque identifiers or tuples consisting of a scheme component, a host component, a port component, and optionally extra data.
The extra data could include the certificate of the site when using encrypted connections, to ensure that if the site's secure certificate changes, the origin is considered to change as well.
These characteristics are defined as follows:
The origin and effective script origin of the URL is whatever is returned by the following algorithm:
Let url be the URL for which the origin is being determined.
Parse url.
If url identifies a resource that is its own trust domain (e.g. it identifies an e-mail on an IMAP server or a post on an NNTP server) then return a globally unique identifier specific to the resource identified by url, so that if this algorithm is invoked again for URLs that identify the same resource, the same identifier will be returned.
If url does not use a server-based naming authority, or if parsing url failed, or if url is not an absolute URL, then return a new globally unique identifier.
Let scheme be the <scheme> component of url, converted to ASCII lowercase.
If the UA doesn't support the protocol given by scheme, then return a new globally unique identifier.
If scheme is "file
", then the user agent may return a
UA-specific value.
Let host be the <host> component of url.
Apply the IDNA ToASCII algorithm to host, with both the AllowUnassigned and UseSTD3ASCIIRules flags set. Let host be the result of the ToASCII algorithm.
If ToASCII fails to convert one of the components of the string, e.g. because it is too long or because it contains invalid characters, then return a new globally unique identifier. [RFC3490]
Let host be the result of converting host to ASCII lowercase.
If there is no <port> component, then let port be the default port for the protocol given by scheme. Otherwise, let port be the <port> component of url.
Return the tuple (scheme, host, port).
In addition, if the URL is in fact associated with
a Document
object that was created by parsing the
resource obtained from fetching URL, and this was
done over a secure connection, then the server's secure
certificate may be added to the origin as additional data.
The origin and effective script origin of a script are determined from another resource, called the owner:
script
elementDocument
to which the
script
element belongs.Document
to which the
attribute node belongs.javascript:
URL that was returned as the
location of an HTTP redirect (or equivalent in
other protocols)javascript:
URL.javascript:
URL in an attributeDocument
of the element on
which the attribute is found.javascript:
URL in a style sheetjavascript:
URL to which a browsing
context is being navigated,
the URL having been provided by the user (e.g. by using a
bookmarklet)Document
of the browsing
context's active document.javascript:
URL to which a browsing
context is being navigated,
the URL having been declared in markupDocument
of the element
(e.g. an a
or area
element) that
declared the URL.javascript:
URL to which a browsing
context is being navigated,
the URL having been provided by scriptThe origin of the script is then equal to the origin of the owner, and the effective script origin of the script is equal to the effective script origin of the owner.
Document
objects and imagesDocument
is in a
browsing context whose sandboxed origin
browsing context flag was set when the
Document
was createdDocument
was generated from a resource
labeled as text/html-sandboxed
Document
is created.Document
or image was returned by the
XMLHttpRequest
APIXMLHttpRequest
object. [XHR]Document
or image was generated from a
javascript:
URLjavascript:
URL.Document
or image was served over the
network and has an address that uses a URL scheme with a
server-based naming authorityDocument
or the URL of the image, as
appropriate.Document
or image was generated from a
data:
URL that was returned as the location
of an HTTP redirect (or equivalent in
other protocols)data:
URL.Document
or image was generated from a
data:
URL found in another
Document
or in a scriptDocument
or script that initiated the navigation to that URL.Document
has the address
"about:blank
"Document
is the origin it was
assigned when its browsing context was created.Document
is an iframe
srcdoc
documentDocument
is the
origin of the Document
's browsing
context's browsing context container's
Document
.Document
or image was obtained in some
other manner (e.g. a data:
URL typed in by
the user, a Document
created using the createDocument()
API, etc)Document
or image is created.When a Document
is created, its effective
script origin is initialized to the origin of
the Document
. However, the document.domain
attribute can
be used to change it.
audio
and video
elementsIf value of the media element's currentSrc
attribute is the
empty string, the origin is the same as the
origin of the element's Document
's
origin.
Otherwise, the origin is equal to the
origin of the absolute URL given by the
media element's currentSrc
attribute.
The Unicode serialization of an origin is the string obtained by applying the following algorithm to the given origin:
If the origin in question is not a
scheme/host/port tuple, then return the literal string "null
" and abort these steps.
Otherwise, let result be the scheme part of the origin tuple.
Append the string "://
" to result.
Apply the IDNA ToUnicode algorithm to each component of the host part of the origin tuple, and append the results — each component, in the same order, separated by U+002E FULL STOP characters (.) — to result. [RFC3490]
If the port part of the origin tuple gives a port that is different from the default port for the protocol given by the scheme part of the origin tuple, then append a U+003A COLON character (:) and the given port, in base ten, to result.
Return result.
The ASCII serialization of an origin is the string obtained by applying the following algorithm to the given origin:
If the origin in question is not a
scheme/host/port tuple, then return the literal string "null
" and abort these steps.
Otherwise, let result be the scheme part of the origin tuple.
Append the string "://
" to result.
Apply the IDNA ToASCII algorithm the host part of the origin tuple, with both the AllowUnassigned and UseSTD3ASCIIRules flags set, and append the results result.
If ToASCII fails to convert one of the components of the string, e.g. because it is too long or because it contains invalid characters, then return the empty string and abort these steps. [RFC3490]
If the port part of the origin tuple gives a port that is different from the default port for the protocol given by the scheme part of the origin tuple, then append a U+003A COLON character (:) and the given port, in base ten, to result.
Return result.
Two origins are said to be the same origin if the following algorithm returns true:
Let A be the first origin being compared, and B be the second origin being compared.
If A and B are both opaque identifiers, and their value is equal, then return true.
Otherwise, if either A or B or both are opaque identifiers, return false.
If A and B have scheme components that are not identical, return false.
If A and B have host components that are not identical, return false.
If A and B have port components that are not identical, return false.
If either A or B have additional data, but that data is not identical for both, return false.
Return true.
Status: Last call for comments
domain
[ = domain ]Returns the current domain used for security checks.
Can be set to a value that removes subdomains, to change the effective script origin to allow pages on other subdomains of the same domain (if they do the same thing) to access each other.
The domain
attribute on Document
objects must be initialized to
the document's domain, if it has one, and the empty
string otherwise. If the value is an IPv6 address, then the square
brackets from the host portion of the <host> component must be omitted from
the attribute's value.
On getting, the attribute must return its current
value, unless the document was created by
XMLHttpRequest
, in which case it must throw an
INVALID_ACCESS_ERR
exception.
On setting, the user agent must run the following algorithm:
If the document was created by XMLHttpRequest
,
throw an INVALID_ACCESS_ERR
exception and abort these
steps.
If the new value is an IP address, let new value be the new value. Otherwise, apply the IDNA ToASCII algorithm to the new value, with both the AllowUnassigned and UseSTD3ASCIIRules flags set, and let new value be the result of the ToASCII algorithm.
If ToASCII fails to convert one of the components of the
string, e.g. because it is too long or because it contains invalid
characters, then throw a SECURITY_ERR
exception and abort
these steps. [RFC3490]
If new value is not exactly equal to the
current value of the document.domain
attribute, then
run these substeps:
If the current value is an IP address, throw a
SECURITY_ERR
exception and abort these steps.
If new value, prefixed by a U+002E FULL
STOP (.), does not exactly match the end of the current value,
throw a SECURITY_ERR
exception and abort these
steps.
If new value matches a suffix in the
Public Suffix List, or, if new value,
prefixed by a U+002E FULL STOP (.), matches the end of a
suffix in the Public Suffix List, then throw a
SECURITY_ERR
exception and abort these steps. [PSL]
Suffixes must be compared after applying the IDNA ToASCII algorithm to them, with both the AllowUnassigned and UseSTD3ASCIIRules flags set, in an ASCII case-insensitive manner. [RFC3490]
Release the storage mutex.
Set the attribute's value to new value.
Set the host part of the effective script origin
tuple of the Document
to new
value.
Set the port part of the effective script origin
tuple of the Document
to "manual override" (a value
that, for the purposes of comparing
origins, is identical to "manual override" but not
identical to any other value).
The domain of a
Document
is the host part of the document's
origin, if that is a scheme/host/port tuple. If it
isn't, then the document does not have a domain.
The domain
attribute is used to enable pages on different hosts of a domain to
access each others' DOMs.
Do not use the document.domain
attribute when
using shared hosting. If an untrusted third party is able to host an
HTTP server at the same IP address but on a different port, then the
same-origin protection that normally protects two different sites on
the same host will fail, as the ports are ignored when comparing
origins after the document.domain
attribute has
been used.