1. 基础设施
本规范依赖于现行标准的基础设施标准。[INFRA]
本规范中使用的一些术语定义在编码、选择器、Web IDL、XML和XML中的命名空间中。[ENCODING][SELECTORS4][WEBIDL][XML][XML-NAMES]
当需要扩展时,可以相应地更新 DOM 标准,或者可以编写一个新标准,该标准可以利用为 适用的规范 提供的可扩展性钩子。
1.1. 树
树 是一个有限的层次树结构。树的顺序是对树的先序、深度优先遍历。
参与树的对象有一个父节点,它要么是 null,要么是一个对象,并且有子节点,它是一个对象的有序集合。对象A的父节点是对象B,则A是B的子节点。
对象的根是它自己,如果它的父为null,否则它的根是它的父的根。树的根是参与该树的任意对象,而该对象的父为null。
如果对象A是对象B的子,或者对象A是对象C的子,而C是B的后代,则对象A被称为对象B的后代。
包含后代是指一个对象或其后代之一。
当且仅当B是A的后代时,称对象A为对象B的祖先。
包含祖先是指一个对象或其祖先之一。
当且仅当B和A共享相同的非空父节点时,称对象A为对象B的同胞。
包含同胞是指一个对象或其同胞之一。
如果A和B在同一个树中,并且A在树的顺序中位于B之前,则称对象A先于对象B。
如果A和B在同一个树中,并且A在树的顺序中位于B之后,则称对象A继于对象B。
一个对象的第一个子节点是其第一个子节点,如果它没有子节点,则为 null。
一个对象的最后一个子节点是其最后一个子节点,如果它没有子节点,则为 null。
一个对象的前一个同胞是指其第一个先于的同胞,如果没有,则为 null。
一个对象的下一个同胞是指其第一个继于的同胞,如果没有,则为 null。
1.2. 有序集合
有序集合解析器接受一个字符串input,然后执行以下步骤:
-
令inputTokens为在 ASCII 空白字符处分割input的结果。
-
令tokens为一个新的有序集合。
- 返回tokens。
有序集合序列化器接受一个set,并返回使用U+0020 SPACE连接的set的串联结果。
1.3. 选择器
要范围匹配选择器字符串selectors与一个node,请执行以下步骤:
-
令s为解析选择器selectors的结果。[SELECTORS4]
-
如果s失败,则抛出一个"
SyntaxError
"DOMException
。 -
返回将选择器与树匹配的结果,其中s与node的根使用范围根node。[SELECTORS4]。
选择器中的命名空间不计划支持,也不会添加。
1.4. 命名空间
要验证qualifiedName,如果qualifiedName不符合QName
生成规则,则抛出一个"InvalidCharacterError
"DOMException
。
要验证并提取namespace和qualifiedName,请执行以下步骤:
-
如果namespace是空字符串,则将其设置为null。
-
验证qualifiedName。
-
将prefix设为null。
-
将localName设为qualifiedName。
-
如果qualifiedName包含U+003A (:),则:
-
将splitResult设为运行严格分割后得到的结果,参数为qualifiedName和U+003A (:)。
-
将prefix设置为splitResult[0]。
-
将localName设置为splitResult[1]。
-
-
如果prefix非null且namespace为null,则抛出一个"
NamespaceError
"DOMException
。 -
如果prefix是"
xml
"且namespace不是XML命名空间,则抛出一个"NamespaceError
"DOMException
。 -
如果qualifiedName或prefix是"
xmlns
"且namespace不是XMLNS命名空间,则抛出一个"NamespaceError
"DOMException
。 -
如果namespace是XMLNS命名空间,且qualifiedName或prefix都不是"
xmlns
",则抛出一个"NamespaceError
"DOMException
。 -
返回namespace、prefix和localName。
2. 事件
2.1. “DOM 事件”简介
在整个 Web 平台中,事件被派发到对象,以标识发生的事件,例如网络活动或用户交互。这些对象实现了EventTarget
接口,因此可以通过调用addEventListener()
来添加事件监听器以观察事件:
obj. addEventListener( "load" , imgFetched) function imgFetched( ev) { // great success …}
事件监听器可以通过使用removeEventListener()
方法删除,传递相同的参数。
或者,也可以通过将AbortSignal
传递给addEventListener()
,然后调用控制器上持有信号的abort()
来删除事件监听器。
事件也是对象,并实现了Event
接口(或派生接口)。在上面的例子中,ev是事件。ev作为参数传递给事件监听器的回调(通常是如上所示的JavaScript函数)。事件监听器通过事件的type
属性值(上例中的"load
")来区分事件。事件的target
属性值返回事件被派发到的对象(如上例中的obj)。
虽然事件通常由用户代理在用户交互或某些任务完成时派发,但应用程序可以通过使用通常称为合成事件的方式派发事件。
// add an appropriate event listener obj. addEventListener( "cat" , function ( e) { process( e. detail) }) // create and dispatch the event var event= new CustomEvent( "cat" , { "detail" : { "hazcheeseburger" : true }}) obj. dispatchEvent( event)
除了用于传递信号外,事件有时也用于让应用程序控制操作中的后续步骤。例如,作为表单提交的一部分,type
属性值为"submit
"的事件被派发。如果调用了该事件的preventDefault()
方法,则表单提交将被终止。希望通过应用程序事件(合成事件)派发该功能的应用程序,可以使用dispatchEvent()
方法的返回值。
if ( obj. dispatchEvent( event)) { // event was not canceled, time for some magic …}
当一个事件被派发到一个参与树(例如,一个元素)的对象时,它也可以到达该对象的祖先上的事件监听器。实际上,该对象的所有包含祖先中捕获为true的事件监听器都将按照树的顺序被调用。然后,如果事件的bubbles
为true,则该对象的所有包含祖先中捕获为false的事件监听器将按照相反的树的顺序被调用。
<!doctype html> < html > < head > < title > Boring example</ title > </ head > < body > < p > Hello< span id = x > world</ span > !</ p > < script > function test( e) { debug( e. target, e. currentTarget, e. eventPhase) } document. addEventListener( "hey" , test, { capture: true }) document. body. addEventListener( "hey" , test) var ev= new Event( "hey" , { bubbles: true }) document. getElementById( "x" ). dispatchEvent( ev) </ script > </ body > </ html >
debug
函数将被调用两次。每次事件的target
属性值将是span
元素。第一次currentTarget
属性值将是document,第二次将是body
元素。eventPhase
属性值将从CAPTURING_PHASE
切换到BUBBLING_PHASE
。如果为span
元素注册了一个事件监听器,eventPhase
属性值将是AT_TARGET
。
2.2. 接口 Event
[Exposed=*]interface {
Event (
constructor DOMString ,
type optional EventInit = {});
eventInitDict readonly attribute DOMString type ;readonly attribute EventTarget ?target ;readonly attribute EventTarget ?srcElement ; // legacyreadonly attribute EventTarget ?currentTarget ;sequence <EventTarget >composedPath ();const unsigned short NONE = 0;const unsigned short CAPTURING_PHASE = 1;const unsigned short AT_TARGET = 2;const unsigned short BUBBLING_PHASE = 3;readonly attribute unsigned short eventPhase ;undefined stopPropagation ();attribute boolean cancelBubble ; // legacy alias of .stopPropagation()undefined stopImmediatePropagation ();readonly attribute boolean bubbles ;readonly attribute boolean cancelable ;attribute boolean returnValue ; // legacyundefined preventDefault ();readonly attribute boolean defaultPrevented ;readonly attribute boolean composed ; [LegacyUnforgeable ]readonly attribute boolean isTrusted ;readonly attribute DOMHighResTimeStamp timeStamp ;undefined initEvent (DOMString ,
type optional boolean =
bubbles false ,optional boolean =
cancelable false ); // legacy };dictionary {
EventInit boolean =
bubbles false ;boolean =
cancelable false ;boolean =
composed false ; };
一个Event
对象通常被称为一个事件。它用于标识某些事情已经发生,例如,一个图像已经完成下载。
一个潜在事件目标是 null
或一个EventTarget
对象。
一个事件有一个关联的目标(一个潜在事件目标)。除非另有说明,否则它为 null。
一个事件有一个关联的相关目标(一个潜在事件目标)。除非另有说明,否则它为 null。
其他规范使用相关目标来定义一个relatedTarget
属性。[UIEVENTS]
一个事件有一个关联的触摸目标列表(一个列表,包含零个或多个潜在事件目标)。除非另有说明,否则它为空列表。
触摸目标列表专门用于定义TouchEvent
接口和相关接口。[TOUCH-EVENTS]
一个事件有一个关联的路径。一个路径是一个列表,包含结构体。每个结构体由一个调用目标(一个EventTarget
对象)、一个在 shadow 树中的调用目标(一个布尔值)、一个shadow 调整后的目标(一个潜在事件目标)、一个相关目标(一个潜在事件目标)、一个触摸目标列表(一个列表,包含潜在事件目标)、一个关闭树的根(一个布尔值)和一个关闭树中的插槽(一个布尔值)。一个路径最初为空列表。
event = new Event(type [, eventInitDict])
- 返回一个新的event,其
type
属性值设置为type。eventInitDict参数允许通过同名对象成员设置bubbles
和cancelable
属性。 event .
type
- 返回event的类型,例如"
click
"、"hashchange
"或"submit
"。 event .
target
- 返回event被分派的对象(其目标)。
event .
currentTarget
- 返回当前正在调用其事件侦听器的回调函数的对象。
event .
composedPath()
- 返回event的调用目标对象(将在其上调用侦听器的对象),但不包括任何节点,这些节点在shadow 树中,其shadow root的模式为"
closed
"且无法从event的currentTarget
到达。 event .
eventPhase
- 返回事件的阶段,它是以下之一:
NONE
、CAPTURING_PHASE
、AT_TARGET
和BUBBLING_PHASE
。 event . stopPropagation()
- 当在树中分派时,调用此方法会阻止event到达当前对象以外的任何对象。
event . stopImmediatePropagation()
- 调用此方法会阻止event在当前侦听器运行结束后到达任何注册的事件侦听器,并且当在树中分派时,也会阻止event到达任何其他对象。
event .
bubbles
- 根据event的初始化方式返回 true 或 false。如果event通过其目标的祖先按相反的树顺序传播,则为 true;否则为 false。
event .
cancelable
- 根据event的初始化方式返回 true 或 false。其返回值并不总是有意义,但 true 可以表示在分派event的过程中,部分操作可以通过调用
preventDefault()
方法来取消。 event . preventDefault()
- 如果在
cancelable
属性值为 true 时调用,并且在执行带有passive
设置为 false 的侦听器时,通知导致分派event的操作需要取消。 event .
defaultPrevented
- 如果成功调用
preventDefault()
表示取消,则返回 true;否则返回 false。 event .
composed
- 根据event的初始化情况返回 true 或 false。如果event调用了超过作为其目标的根的
ShadowRoot
节点的监听器,则返回 true;否则返回 false。 event .
isTrusted
- 如果event由用户代理分派,则返回 true,否则返回 false。
event .
timeStamp
- 以毫秒为单位返回event的时间戳,相对于发生时间。
type
属性必须返回初始化时的值。当创建一个事件时,必须将该属性初始化为空字符串。
currentTarget
属性必须返回初始化时的值。当创建一个事件时,必须将该属性初始化为 null。
composedPath()
方法的步骤为:
-
让composedPath成为一个空的列表。
-
如果path为空,则返回composedPath。
-
让currentTarget成为this的
currentTarget
属性值。 -
追加currentTarget到composedPath。
-
将currentTargetIndex设为 0。
-
将currentTargetHiddenSubtreeLevel设为 0。
-
将index设为path的大小 - 1。
-
当index大于或等于 0 时:
-
将currentHiddenLevel和maxHiddenLevel设为currentTargetHiddenSubtreeLevel。
-
将index设为currentTargetIndex - 1。
-
当index大于或等于 0 时:
-
将currentHiddenLevel和maxHiddenLevel设为currentTargetHiddenSubtreeLevel。
-
将index设为currentTargetIndex + 1。
-
当index小于path的大小时:
-
返回composedPath。
eventPhase
属性必须返回初始化时的值,该值必须是以下之一:
NONE
(数值 0)- 事件当前未被分派时处于此阶段。
CAPTURING_PHASE
(数值 1)- 当一个事件被分派到一个参与树的对象时,它将在到达其目标之前处于此阶段。
AT_TARGET
(数值 2)- 当一个事件被分派时,它将在其目标上处于此阶段。
BUBBLING_PHASE
(数值 3)- 当一个事件被分派到一个参与树的对象时,它将在到达其目标后处于此阶段。
最初该属性必须初始化为NONE
。
每个事件都具有以下关联标志,最初都未设置:
- 停止传播标志
- 立即停止传播标志
- 取消标志
- 在被动侦听器中的标志
- 合成标志
- 初始化标志
- 分派标志
stopPropagation()
方法的步骤是设置this的停止传播标志。
cancelBubble
获取步骤是如果this的停止传播标志已设置,则返回 true;否则返回 false。
cancelBubble
设置步骤是如果给定值为
true,则设置this的停止传播标志;否则不执行任何操作。
stopImmediatePropagation()
方法的步骤是设置this的停止传播标志和this的立即停止传播标志。
bubbles
和cancelable
属性必须返回初始化时的值。
要设置取消标志,给定一个事件event,如果event的cancelable
属性值为
true 并且event的在被动侦听器中的标志未设置,则设置event的取消标志,否则不执行任何操作。
returnValue
获取步骤是如果this的取消标志已设置,则返回 false;否则返回 true。
returnValue
设置步骤是如果给定值为
false,则设置取消标志,并将this作为参数;否则不执行任何操作。
preventDefault()
方法的步骤是将取消标志设置为this。
在某些情况下,调用preventDefault()
无效。建议用户代理在开发者控制台中记录具体原因,以帮助调试。
defaultPrevented
获取步骤是如果this的取消标志已设置,则返回 true;否则返回 false。
composed
获取步骤是如果this的合成标志已设置,则返回 true;否则返回 false。
isTrusted
属性必须返回初始化时的值。当创建一个事件时,必须将该属性初始化为 false。
isTrusted
是一个方便的属性,指示一个事件是否由用户代理分派(而不是使用dispatchEvent()
)。唯一的传统例外是click()
,它导致用户代理分派一个isTrusted
属性初始化为
false 的事件。
timeStamp
属性必须返回初始化时的值。
要初始化一个event,使用type、bubbles和cancelable,运行以下步骤:
initEvent()
与事件构造函数是多余的,并且无法设置composed
。它必须为了遗留内容而支持。
2.3.
对 Window
接口的传统扩展
partial interface Window { [Replaceable ]readonly attribute (Event or undefined )event ; // legacy };
每个 Window
对象都有一个关联的 当前事件(未定义或一个 Event
对象)。除非另有说明,否则它是未定义的。
event
的 getter 步骤是返回 this 的 当前事件。
强烈建议 Web 开发者依赖传递给事件监听器的 Event
对象,因为这将产生更具可移植性的代码。此属性在 workers 或 worklets 中不可用,并且对于在 shadow trees 中分派的事件是不准确的。
2.4. 接口 CustomEvent
[Exposed=*]interface :
CustomEvent Event {(
constructor DOMString ,
type optional CustomEventInit = {});
eventInitDict readonly attribute any detail ;undefined initCustomEvent (DOMString ,
type optional boolean =
bubbles false ,optional boolean =
cancelable false ,optional any =
detail null ); // legacy };dictionary :
CustomEventInit EventInit {any =
detail null ; };
事件 使用 CustomEvent
接口可以用于携带自定义数据。
event = new CustomEvent(type [, eventInitDict])
- 其工作方式类似于
Event
的构造函数,但 eventInitDict 参数现在还允许设置detail
属性。 event .
detail
- 返回创建 event 时的任何自定义数据。 通常用于合成事件。
detail
属性必须返回它初始化时的值。
initCustomEvent(type, bubbles, cancelable, detail)
方法的步骤如下:
2.5. 构造事件
规范可能会为所有或某些事件定义事件构造步骤。该算法接收一个事件event和一个EventInit
eventInitDict,如内部事件创建步骤中所示。
这个构造方式可用于Event
子类,它们具有比简单的初始化字典成员和IDL属性之间一对一映射更复杂的结构。
要使用eventInterface 创建事件,该接口必须是Event
或继承自它的接口,并且可选地提供realm
realm,运行以下步骤:
-
如果未提供realm,则将其设置为null。
-
将dictionary设置为将JavaScript值undefined转换为eventInterface构造函数所接受的字典类型的结果。(此字典类型将是
EventInit
或继承自它的字典类型。)如果需要成员,这种方法不起作用;请参见whatwg/dom#600。
-
运行内部事件创建步骤,以eventInterface、realm、该事件信号发生的时间和dictionary为参数,得到event。
-
将event的
isTrusted
属性初始化为true。 -
返回event。
创建事件用于需要分别创建和分发事件的其他规范,而不是简单地触发事件。它确保事件的属性初始化为正确的默认值。
内部事件创建步骤,给定eventInterface、realm、time和dictionary,如下所示:
-
使用eventInterface创建一个新对象作为event的结果。如果realm非空,则使用该realm;否则,使用Web IDL中定义的默认行为。
截至本文撰写时,Web IDL 尚未定义任何默认行为;请参见whatwg/webidl#135。
-
设置event的初始化标志。
-
将event的
timeStamp
属性初始化为给定time和event的相关全局对象的相对高分辨率粗略时间。 -
遍历dictionary中的member→value,如果event有一个属性,其标识符是member,则将该属性初始化为value。
-
运行事件构造步骤,参数为event和dictionary。
-
返回event。
2.6. 定义事件接口
通常,在定义一个继承自Event
的新接口时,请务必征求WHATWG或W3C WebApps
WG社区的反馈。
CustomEvent
接口可以作为起点。然而,不要引入任何init*Event()
方法,因为它们与构造函数是冗余的。继承自Event
接口的接口中如果包含此类方法,也只是出于历史原因。
2.7. 接口 EventTarget
[Exposed=*]interface {
EventTarget constructor ();undefined addEventListener (DOMString ,
type EventListener ?,
callback optional (AddEventListenerOptions or boolean )= {});
options undefined removeEventListener (DOMString ,
type EventListener ?,
callback optional (EventListenerOptions or boolean )= {});
options boolean dispatchEvent (Event ); };
event callback interface {
EventListener undefined (
handleEvent Event ); };
event dictionary {
EventListenerOptions boolean =
capture false ; };dictionary :
AddEventListenerOptions EventListenerOptions {boolean ;
passive boolean =
once false ;AbortSignal ; };
signal
一个 EventTarget
对象表示一个目标,当某些事情发生时,一个事件可以被派发到该目标。
每个 EventTarget
对象都有一个相关的事件监听器列表(一个由零个或多个事件监听器组成的列表)。它最初是空的列表。
一个事件监听器 可以用于观察特定的事件,它由以下部分组成:
- 类型(一个字符串)
- 回调(null或一个
EventListener
对象) - 捕获(一个布尔值,初始值为false)
- 被动(null或一个布尔值,初始值为null)
- 一次性(一个布尔值,初始值为false)
- 信号(null或一个
AbortSignal
对象) - 已移除(用于记录的布尔值,初始值为false)
虽然回调是一个 EventListener
对象,事件监听器
是一个更广泛的概念,如上所述。
每个 EventTarget
对象还有一个相关的获取父级算法,
该算法接收一个事件
event,并返回一个EventTarget
对象。除非另有说明,它返回null。
每个 EventTarget
对象可以有一个相关的激活行为算法。该激活行为算法接收一个事件,如
派发
算法中所示。
这是因为用户代理在某些EventTarget
对象上执行某些操作,例如
area
元素,以响应其MouseEvent
的type
属性为click
的合成事件。由于Web兼容性问题,它未能被移除,并且现在成为定义激活某些内容的固定方式。[HTML]
每个 EventTarget
对象如果具有激活行为,还可以同时(而非单独)具有遗留预激活行为算法
和遗留取消激活行为
算法。
这些算法仅存在于复选框和单选框的
input
元素中,
不适用于其他任何内容。[HTML]
target = new EventTarget();
-
创建一个新的
EventTarget
对象,开发者可以使用它来派发并 监听事件。 target . addEventListener(type, callback [, options])
-
为
type
属性值为type的事件附加一个事件侦听器。callback参数设置将在事件分派时调用的回调函数。当options为true时,监听器在捕获阶段触发;当为false或未设置时,监听器在冒泡阶段触发。无论设置如何,若事件处于目标阶段,监听器均会被触发。
当options设置为true时,表示监听器为被动模式,不会调用
preventDefault()
来取消事件。当options设置为true时,表示监听器仅触发一次,触发后将被移除。
若为options指定了
AbortSignal
,当信号被中止时,监听器将被移除。若已存在相同type、callback和capture的事件监听器,则不会再次添加。
target . removeEventListener(type, callback [, options])
-
移除target中与type、callback和options匹配的事件监听器。
target . dispatchEvent(event)
-
派发event事件,并返回true,若事件的
cancelable
属性为false或未调用preventDefault()
,否则返回false。
要展开 options,请执行以下步骤:
-
如果options是布尔值,则返回options。
-
返回options["
capture
"]。
要进一步展开 options,请执行以下步骤:
new EventTarget()
构造函数步骤不执行任何操作。
由于其他地方声明的默认值,返回的EventTarget
的
获取父级算法将返回null,并且它没有激活行为、遗留预激活行为,
或遗留取消激活行为。
将来我们可能会允许自定义获取父级算法。请告诉我们
这对您的程序是否有用。目前,所有作者创建的EventTarget
不参与树结构。
默认被动值,给定一个事件类型type和一个EventTarget
eventTarget,由下列步骤决定:
要添加事件监听器,给定一个EventTarget
对象eventTarget和一个事件监听器listener,请执行以下步骤:
-
若eventTarget是一个
ServiceWorkerGlobalScope
对象,其service worker的脚本资源的曾经评估过的标志被设置,且listener的类型与任何service worker 事件的类型
属性值匹配,则向控制台报告一个警告,提示这可能不会产生预期结果。[SERVICE-WORKERS] -
若listener的回调为null,则返回。
-
若listener的被动为null,则将其设置为listener的默认被动值,根据listener的类型 和eventTarget。
-
若eventTarget的事件监听器列表不包含一个事件监听器,其类型是listener的类型,回调是listener的回调,且捕获是listener的捕获,则追加 listener到eventTarget的事件监听器列表中。
-
- 移除事件监听器,使用eventTarget和listener。
添加事件监听器的概念是为了确保事件处理器使用相同的代码路径。[HTML]
addEventListener(type, callback, options)
方法步骤为:
要移除事件监听器,给定一个EventTarget
对象eventTarget和一个事件监听器 listener,请执行以下步骤:
-
如果eventTarget是
ServiceWorkerGlobalScope
对象,并且它的服务工作者的要处理的事件类型集合包含listener的类型,那么报告一个警告到控制台,表明这可能不会产生预期的结果。[SERVICE-WORKERS]
HTML 需要这个来定义事件处理器。[HTML]
要移除所有事件监听器,给定一个EventTarget
对象eventTarget,对其每个
listener的事件监听器列表项,移除事件监听器,使用eventTarget和listener。
HTML 需要这个来定义document.open()
。[HTML]
removeEventListener(type, callback, options)
方法步骤为:
-
令capture为展开options的结果。
-
如果this的事件 监听器列表 包含一个事件监听器, 其类型是type,回调是 callback,且捕获是capture,则移除事件监听器,使用this和该事件监听器。
事件侦听器列表不会包含具有相同type、callback和capture的多个事件侦听器,因为添加事件侦听器会防止这种情况发生。
dispatchEvent(event)
方法步骤为:
-
若event的派发标志已设置,或其初始化标志未设置,则抛出一个“
InvalidStateError
”DOMException
。 -
将event的
isTrusted
属性初始化为false。
2.8. 观察事件监听器
一般来说,开发者不会期望事件监听器的存在是可观察的。 事件监听器的影响由其回调决定。也就是说, 开发者添加一个无操作的事件监听器时不会期望它有任何副作用。
不幸的是,一些事件API的设计使得要高效实现它们就需要观察事件侦听器。这使得侦听器的存在是可观察的,即使是空的侦听器也可能对应用程序的行为产生显著的性能影响。例如,可以用于阻止异步滚动的触摸和滚轮事件。在某些情况下,可以通过仅在存在至少一个非被动
侦听器时将事件指定为可取消
来缓解这一问题。例如,非被动
触摸事件
侦听器必须阻止滚动,但如果所有侦听器都是被动
的,则可以通过使触摸事件
不可取消(从而忽略对preventDefault()
的调用)来允许滚动并行开始。因此,分派事件的代码能够观察到非被动
侦听器的缺失,并使用该信息来清除正在分派的事件的可取消
属性。
理想情况下,任何新的事件API都应定义为不需要此属性。(请使用whatwg/dom进行讨论。)
要获取遗留的服务工作者获取事件侦听器回调,给定一个ServiceWorkerGlobalScope
global,请运行以下步骤。这些步骤将返回一个EventListener
对象的列表。
2.9. 分发事件
要将一个事件分发给一个目标,可选带有legacy target override flag和legacyOutputDidListenersThrowFlag,请按以下步骤操作:
-
设置event的分发标志。
-
如果未给出legacy target override flag,则将targetOverride设置为目标,否则设置为目标的关联的
文档
。[HTML]legacy target override flag仅由HTML使用,且仅当目标是一个
窗口
对象时使用。 -
将activationTarget设置为null。
-
将relatedTarget设置为针对目标重新定位event的relatedTarget的结果。
-
如果目标不是relatedTarget或目标是event的relatedTarget,则:
-
将touchTargets设置为一个新的列表。
-
对于每个touchTarget,它在event的触摸目标列表中,追加针对目标重新定位touchTarget的结果到touchTargets中。
-
通过event、目标、targetOverride、relatedTarget、touchTargets,并设置为false,附加到事件路径。
-
如果event是一个
鼠标事件
对象,且event的类型
属性为"click
",则isActivationEvent为true;否则为false。 -
如果isActivationEvent为true且目标具有激活行为,则将activationTarget设置为目标。
-
将slot-in-closed-tree设置为false。
-
将parent设置为调用目标的获取父项结果的event。
-
当parent非空时:
-
如果slottable非空:
-
将relatedTarget设置为针对parent重新定位event的relatedTarget的结果。
-
将touchTargets设置为一个新的列表。
-
对于每个touchTarget ,它在event的触摸目标列表中,追加针对parent重新定位touchTarget的结果到touchTargets中。
-
如果parent是一个
窗口
对象,或parent是一个节点且目标的根是parent的包括影子在内的包容性祖先,则: -
否则,如果parent是relatedTarget,则将parent设置为null。
-
否则,将目标设置为parent,然后:
-
如果parent非空,则将parent设置为调用parent的获取父项结果的event。
-
将slot-in-closed-tree设置为false。
-
-
如果clearTargetsStruct的影子调整目标、clearTargetsStruct的relatedTarget,或者clearTargetsStruct的触摸目标列表中的
事件目标
对象是一个节点,且其根是一个影子根,则clearTargets为true;否则为false。 -
如果activationTarget非空且activationTarget具有旧式预激活行为,则运行activationTarget的旧式预激活行为。
-
-
将event的
当前目标
属性设置为null。 -
将event的路径设置为空列表。
-
如果clearTargets,则:
-
将event的目标设置为null。
-
将event的relatedTarget设置为null。
-
将event的触摸目标列表设置为空列表。
-
-
如果activationTarget非空,则:
-
如果event的取消标志已设置,则返回false;否则返回true。
要附加到事件路径,给定一个event、invocationTarget、shadowAdjustedTarget、relatedTarget、touchTargets,以及slot-in-closed-tree,请运行这些步骤:
-
将invocationTargetInShadowTree设置为false。
-
如果invocationTarget是一个节点,且其根是一个影子根,则将invocationTargetInShadowTree设置为true。
-
将root-of-closed-tree设置为false。
-
如果invocationTarget是一个影子根,且其模式是"
closed
",则将root-of-closed-tree设置为true。 -
追加一个新的结构到event的路径,其调用目标是invocationTarget,调用目标在影子树中是invocationTargetInShadowTree,影子调整目标是shadowAdjustedTarget,relatedTarget是relatedTarget,触摸目标列表是touchTargets,关闭树的根是root-of-closed-tree,以及slot-in-closed-tree是slot-in-closed-tree。
要调用,给定一个struct、event、阶段,以及可选的legacyOutputDidListenersThrowFlag,请运行这些步骤:
-
将event的目标设置为event的路径中的最后一个结构,其影子调整目标非空,且为struct或struct之前的结构。
-
将event的relatedTarget设置为struct的relatedTarget。
-
如果event的停止传播标志已设置,则返回。
-
将invocationTargetInShadowTree设置为struct的调用目标在影子树中。
-
将found设置为运行内部调用通过event、listeners、阶段、invocationTargetInShadowTree,以及如果给出的话legacyOutputDidListenersThrowFlag的结果。
-
如果found为false且event的
isTrusted
属性为true, 则:-
将originalEventType设置为event的
类型
属性值。 -
如果event的
类型
属性值匹配下表中的任意字符串,将event的类型
属性值设置为同一行匹配字符串旁的字符串,否则返回。事件类型 旧式事件类型 " animationend
"" webkitAnimationEnd
"" animationiteration
"" webkitAnimationIteration
"" animationstart
"" webkitAnimationStart
"" transitionend
"" webkitTransitionEnd
" -
内部调用通过event、listeners、阶段、invocationTargetInShadowTree,以及如果给出的话legacyOutputDidListenersThrowFlag。
-
将event的
类型
属性值设置为originalEventType。
-
要内部调用,给定一个event、listeners、阶段、invocationTargetInShadowTree,以及可选的legacyOutputDidListenersThrowFlag,请运行这些步骤:
-
让 found 为 false。
-
对于每个 listener 在 listeners 中,其 移除状态为 false:
-
将 found 设为 true。
-
如果 listener 的 once 为 true,则 移除 listener 从 event 的
currentTarget
属性值的 事件监听器列表。 -
让 currentEvent 为 undefined。
-
如果 global 是一个
Window
对象,则: -
如果 global 是一个
Window
对象,则 记录事件监听器的计时信息,使用 event 和 listener。 -
调用用户对象的操作,使用 listener 的 回调,"
handleEvent
",«event»,以及 event 的currentTarget
属性值。如果这会抛出一个异常 exception,则:-
设置 legacyOutputDidListenersThrowFlag(如果提供)。
legacyOutputDidListenersThrowFlag 仅被 Indexed Database API 使用。[INDEXEDDB]
-
取消设定 event 的 被动监听器标志。
-
如果 event 的 停止立即传播标志已设置,则返回 found。
-
返回 found。
2.10. 触发事件
要在target上触发事件,事件名为e,可选地使用eventConstructor,并描述如何初始化IDL属性,以及legacy target override flag,请执行以下步骤:
在 DOM 的上下文中,"Fire" 是创建、初始化和分派一个事件的缩写。Fire an event 使得这个过程更容易表达。
如果事件需要其
bubbles
或cancelable
属性初始化,
可以这样写:“fire an
event named submit
at target
with its cancelable
attribute initialized to true”。
或者,当需要自定义构造函数时,可以这样写:“fire an event named click
at target
using MouseEvent
with its detail
attribute initialized to 1”。
有时返回值很重要:
-
让 doAction 成为 firing an event named
like
at target 的结果。 -
如果 doAction 为真,那么……
2.11. 动作与事件的区别
一个事件
表示一个发生的事情,而不是一个动作。换句话说,它代表一个算法的通知,并且可以用于影响该算法的未来执行过程(例如,通过调用preventDefault()
)。事件
不得用于作为动作或启动某个算法的触发器。这不是它们的用途。
这里特别指出这一点是因为之前的DOM迭代中有一个与事件
相关的“默认动作”的概念,这给人们带来了错误的理解。事件
不代表或引发动作,它们只能用于影响正在进行的动作。
3. 中止正在进行的活动
虽然Promise没有内置的中止机制,但许多使用Promise的API需要中止语义。AbortController
旨在通过提供abort()
方法来支持这些需求,该方法可切换对应AbortSignal
对象的状态。希望支持中止的API可以接受一个AbortSignal
对象,并使用其状态来决定如何继续。
依赖于AbortController
的API建议通过拒绝任何未决的Promise来响应abort()
,并使用AbortSignal
的abort reason
。
一个假设的doAmazingness({ ... })
方法可以通过接受AbortSignal
对象来支持中止,类似如下:
const controller = new AbortController();
const signal = controller. signal;
startSpinner();
doAmazingness({ ..., signal })
. then( result => ...)
. catch ( err => {
if ( err. name == 'AbortError' ) return ;
showUserErrorMessage();
})
. then(() => stopSpinner());
// …
controller. abort();
doAmazingness
could be implemented as follows:
function doAmazingness({ signal}) {
return new Promise(( resolve, reject) => {
signal. throwIfAborted();
// Begin doing amazingness, and call resolve(result) when done.
// But also, watch for signals:
signal. addEventListener( 'abort' , () => {
// Stop doing amazingness, and:
reject( signal. reason);
});
});
}
不返回promise的API可以选择以类似的方式做出反应,或者选择完全不展示AbortSignal
的中止原因。addEventListener()
就是一个适合后者的API例子。
需要更精细控制的API可以根据需要扩展AbortController
和AbortSignal
对象。
3.1.
接口 AbortController
[Exposed=*]interface {
AbortController constructor (); [SameObject ]readonly attribute AbortSignal signal ;undefined abort (optional any ); };
reason
controller = new AbortController()
- 返回一个新的controller,其
signal
被设置为新创建的AbortSignal
对象。 controller . signal
- 返回与此对象关联的
AbortSignal
对象。 controller . abort(reason)
- 调用此方法将把reason存储在此对象的
AbortSignal
的中止原因中,并向任何观察者发出信号,表示相关活动将被中止。如果reason未定义,则会存储一个"AbortError
"DOMException
。
一个AbortController
对象有一个关联的信号(一个AbortSignal
对象)。
new AbortController()
构造函数步骤如下:
-
让signal成为一个新的
AbortSignal
对象。
signal
的getter步骤是返回this的signal。
abort(reason)
方法步骤是在signal abort上执行,带有reason如果给定。
在AbortController
的controller上带有可选的reason执行signal abort,如果reason被提供。
3.2. 接口AbortSignal
[Exposed=*]interface :
AbortSignal EventTarget { [NewObject ]static AbortSignal abort (optional any ); [
reason Exposed =(Window ,Worker ),NewObject ]static AbortSignal timeout ([EnforceRange ]unsigned long long ); [
milliseconds NewObject ]static AbortSignal _any (sequence <AbortSignal >);
signals readonly attribute boolean aborted ;readonly attribute any reason ;undefined throwIfAborted ();attribute EventHandler onabort ; };
AbortSignal . abort(reason)
- 返回一个
AbortSignal
实例,其中止原因设置为reason(如果未定义则为"AbortError
"DOMException
)。 AbortSignal . any(signals)
- 返回一个
AbortSignal
实例,该实例将在任一signals中止时中止。其中止原因将被设置为导致中止的signals中的某一个。 AbortSignal . timeout(milliseconds)
- 返回一个
AbortSignal
实例,该实例将在milliseconds毫秒后中止。其中止原因将被设置为"TimeoutError
"DOMException
。 signal . aborted
- 如果signal的
AbortController
已发出中止信号,则返回true;否则返回false。 signal . reason
- 返回signal的中止原因。
signal . throwIfAborted()
- 如果signal的
AbortController
已发出中止信号,则抛出signal的中止原因;否则不执行任何操作。
一个AbortSignal
对象有一个关联的中止原因(一个JavaScript值),其初始状态为未定义。
一个AbortSignal
对象有一个关联的中止算法(一组将在中止时执行的算法),其初始状态为空。
中止算法使得具有复杂要求的API能够合理地响应abort()
。例如,给定API的中止原因可能需要传播到跨线程环境,例如service worker。
一个AbortSignal
对象有一个依赖项(一个布尔值),其初始状态为false。
一个AbortSignal
对象有一个关联的源信号(一组AbortSignal
对象),其初始状态为空。
一个AbortSignal
对象有一个关联的依赖信号(一组依赖于对象的AbortSignal
对象),其初始状态为空。
静态方法abort(reason)
的步骤如下:
-
让signal成为一个新的
AbortSignal
对象。 -
将signal的中止原因设置为reason,如果给定;否则设置为新的"
AbortError
"DOMException
。 - 返回signal。
静态方法timeout(milliseconds)
的步骤如下:
-
让signal成为一个新的
AbortSignal
对象。 -
让global成为signal的相关全局对象。
-
在超时后运行步骤,给定global、"
AbortSignal-timeout
"、milliseconds,以及以下步骤:-
在全局任务队列中排队,在global上,基于signal和新的"
TimeoutError
"DOMException
执行signal abort。
在此超时时间内,如果signal已为其
abort
事件注册了任何事件监听器,则必须从global到signal保持一个强引用。 -
-
返回signal。
静态方法any(signals)
的步骤是返回创建一个依赖的中止信号的结果,使用signals、AbortSignal
和当前领域。
aborted
getter步骤是返回true如果this已中止;否则返回false。
throwIfAborted()
方法步骤是抛出this的中止原因,如果this已中止。
此方法主要用于当接受AbortSignal
的函数希望在特定检查点抛出(或返回一个被拒绝的promise),而不是将AbortSignal
传递给其他方法时。例如,以下函数允许在每次尝试轮询条件之间中止。这为中止轮询过程提供了机会,即使实际的异步操作(即
)不接受AbortSignal
。
async function waitForCondition( func, targetValue, { signal} = {}) { while ( true ) { signal? . throwIfAborted(); const result= await func(); if ( result=== targetValue) { return ; } } }
属性 onabort
是一个 事件处理程序 IDL 属性,用于 onabort
事件处理程序,其 事件处理程序事件类型 是 abort
。
对 AbortSignal
对象的更改代表了相应的 AbortController
对象的意图,但观察 AbortSignal
对象的 API 可以选择忽略这些更改。例如,如果操作已经完成。
当 AbortSignal
对象的 中止原因 不为未定义时,
该对象被认为是 已中止。
要向 AbortSignal
对象 signal 中 添加
一个算法 algorithm:
要 发出中止信号,
给定一个 AbortSignal
对象 signal 和一个可选的 reason:
-
如果 signal 已经 中止,则返回。
-
将 signal 的 中止原因 设为 reason(如果提供);否则设为一个新的 "
AbortError
"DOMException
。 -
将 dependentSignalsToAbort 设为一个新的 列表。
-
运行中止步骤 对于 signal。
-
对于每个 dependentSignal 在 dependentSignalsToAbort 中,运行中止步骤 对于 dependentSignal。
要 运行中止步骤 对于一个
AbortSignal
signal:
要从一组 AbortSignal
对象 signals 中 创建一个依赖中止信号,
使用 signalInterface(必须是 AbortSignal
或继承自它的接口)和 realm:
3.2.1. 垃圾回收
一个非 中止的
依赖的
AbortSignal
对象,在其 源信号 非空且其已注册事件监听器
监听其 abort
事件或其 中止算法 非空时,不能被垃圾回收。
3.3.
在 API 中使用 AbortController
和 AbortSignal
对象
任何使用 promises 表示可以中止操作的 Web 平台 API 必须遵循以下规则:
- 通过
AbortSignal
对象通过signal
字典成员接受信号。 - 通过使用
AbortSignal
对象的 中止原因 拒绝 promise,以传达操作已中止。 - 如果
AbortSignal
已经 中止,则立即拒绝,否则: - 使用 中止算法 机制来观察
AbortSignal
对象的变化,并以不会与其他观察者发生冲突的方式进行。
不使用 promises 的 API 仍应尽可能遵循上述规则。
4. 节点
4.1. “DOM”简介
在其原始意义上,“DOM”是一个用于访问和操作文档(特别是HTML和XML文档)的API。在本规范中,术语“文档”用于任何基于标记的资源,从简短的静态文档到包含丰富多媒体的长篇文章或报告,以及功能齐全的交互式应用程序。
每个这样的文档都表示为一个节点树。树中的一些节点可以有子节点,而其他的总是叶子节点。
为了说明这一点,考虑以下HTML文档:
<!DOCTYPE html> < html class = e > < head >< title > Aliens?</ title ></ head > < body > Why yes.</ body > </ html >
它表示如下:
请注意,由于HTML解析的神奇之处,并非所有ASCII空白字符都被转化为文本
节点,但总体概念是清晰的。标记进入,树形节点输出。
可以使用非常棒的Live DOM Viewer来更详细地探索这个问题。
4.2. 节点树
节点是实现了实现Node
的对象。节点参与一个称为节点树的树。
实际上,你处理的是更具体的对象。
实现了实现Node
的对象也实现了一个继承的接口:Document
、DocumentType
、DocumentFragment
、Element
、CharacterData
或Attr
。
实现了DocumentFragment
的对象有时会实现ShadowRoot
。
实现了Element
的对象通常也会实现一个继承的接口,例如HTMLAnchorElement
。
实现了CharacterData
的对象也会实现一个继承的接口:Text
、ProcessingInstruction
或Comment
。
实现了Text
的对象有时会实现CDATASection
。
因此,每个节点的主要接口是以下之一:Document
、DocumentType
、DocumentFragment
、ShadowRoot
、Element
或Element
的一个继承接口,Attr
、Text
、CDATASection
、ProcessingInstruction
或Comment
。
为简洁起见,本规范将实现了Node
和继承接口NodeInterface
的对象称为NodeInterface
节点。
Document
-
按树顺序:
-
可选地包含一个
DocumentType
节点。 -
零个或多个
ProcessingInstruction
或Comment
节点。
DocumentFragment
Element
-
零个或多个
Element
或CharacterData
节点。 DocumentType
CharacterData
Attr
-
没有子节点。
Attr
节点参与一个树的历史原因;它们从不具有(非空)父节点或任何子节点,因此在一个树中是孤立的。
要确定节点node的长度,请执行以下步骤:
-
如果node是
DocumentType
或Attr
节点,则返回0。 -
如果node是
CharacterData
节点,则返回node的数据的长度。 -
返回node的子节点的数量。
4.2.1. 文档树
文档元素是一个文档中其父节点是该文档的元素;如果不存在,则为 null。
当一个节点被认为在文档中,它在文档树中。术语在文档中不再被使用。它表明使用它的标准尚未更新,以考虑到影子树。
4.2.2. 影子树
影子根总是通过其宿主附加到另一个节点树。因此,影子树永远不会是孤立的。影子根的宿主的节点树有时被称为光树。
当一个节点的包含影子的根是一个文档时,该节点被认为是已连接的。
4.2.2.1. 插槽
一个插槽有一个关联的名称(一个字符串)。除非另有说明,否则它是空字符串。
-
如果element是一个插槽,localName是
name
,且namespace为空,则:
一个插槽是一个影子树中的第一个,在树顺序中,其名称为空字符串的插槽,有时被称为“默认插槽”。
一个插槽有一个关联的分配的节点(一个可插槽对象的列表)。除非另有说明,否则它是空的。
4.2.2.2. 可插槽对象
一个可插槽对象有一个关联的名称(一个字符串)。除非另有说明,否则它是空字符串。
-
如果localName是
slot
且namespace为空,则:
字母A 可插槽元素有一个关联的已分配插槽(null或插槽)。 除非另有说明,否则它为null。字母A 可插槽元素是已分配的,如果它的已分配插槽非null。
一个可插槽对象有一个关联的手动插槽分配(null或插槽)。除非另有说明,否则它是null。
一个可插槽对象的手动插槽分配可以使用对插槽的弱引用来实现,因为这个变量不能直接从脚本访问。
4.2.2.3. 查找插槽和可插槽对象
要为给定的可插槽对象slottable和一个可选的开放标志(除非另有说明,否则不设置)查找插槽,请执行以下步骤:
-
如果slottable的父节点为null,则返回null。
-
如果shadow为null,则返回null。
-
如果开放标志被设置,且shadow的模式不是“
open
”,则返回null。 -
如果shadow的插槽分配为“
manual
”,则返回shadow的后代中其手动分配节点包含slottable的插槽,如果有的话;否则返回null。
要为给定的插槽slot查找可插槽对象,请执行以下步骤:
要为给定的插槽slot查找扁平化可插槽对象,请执行以下步骤:
-
令result为空列表。
-
令slottables为查找可插槽对象给定slot的结果。
-
对于slottables中的每个node:
-
-
令temporaryResult为查找扁平化可插槽对象给定node的结果。
-
按顺序将temporaryResult中的每个可插槽对象附加到result。
-
-
否则,将node附加到result。
-
-
返回result。
4.2.2.4. 分配可插槽对象和插槽
要为插槽slot 分配可插槽对象,请运行以下步骤:
-
令slottables为查找可插槽对象给定slot的结果。
-
将slot的已分配节点设置为slottables。
-
对于slottables中的每个slottable,将slottable的已分配插槽设置为slot。
要为给定节点root 分配树的可插槽对象,请按树顺序为root的包含后代中的每个插槽slot分配可插槽对象。
要为给定可插槽对象slottable 分配插槽,请运行以下步骤:
4.2.2.5. 发出插槽变更信号
每个相同来源窗口代理都有一个信号插槽(集合中的一部分插槽),其初始值为空。[HTML]
要为插槽slot 发出插槽变更信号,请运行以下步骤:
4.2.3. 变异算法
要在将node插入parent中的child之前 确保预插入的有效性,请运行以下步骤:
-
如果parent不是
Document
、DocumentFragment
或Element
节点,则抛出一个“HierarchyRequestError
”DOMException
。 -
如果node是parent的包含宿主的包容性祖先,则抛出一个“
HierarchyRequestError
”DOMException
。 -
如果child不为null,且其父节点不是parent,则抛出一个“
NotFoundError
”DOMException
。 -
如果node不是
DocumentFragment
、DocumentType
、Element
或CharacterData
节点,则抛出一个“HierarchyRequestError
”DOMException
。 -
如果node是一个
文本
节点且parent是一个文档,或node是一个文档类型,且parent不是文档,则抛出一个“HierarchyRequestError
”DOMException
。 -
如果parent是一个文档,且根据node实现的接口,下列语句中的任何一个为真,则抛出一个“
HierarchyRequestError
”DOMException
。
要预插入 node到parent的child之前,请运行以下步骤:
-
确保预插入的有效性 node到parent的child之前。
-
令referenceChild为child。
-
如果referenceChild是node,则将referenceChild设置为node的下一个兄弟节点。
-
插入node到parent的referenceChild之前。
-
返回node。
规范可以为所有或一些节点定义插入步骤。该算法将传递insertedNode,如下所示的插入算法。这些步骤不能修改insertedNode参与的节点树,创建浏览上下文,触发事件,或以其他方式执行JavaScript。然而,这些步骤可以排队任务异步执行这些操作。
虽然插入步骤不能执行JavaScript(以及其他事情),但它们确实会产生脚本可观察到的后果。请考虑以下示例:
const h1 = document. querySelector( 'h1' );
const fragment = new DocumentFragment();
const script = fragment. appendChild( document. createElement( 'script' ));
const style = fragment. appendChild( document. createElement( 'style' ));
script. innerText= 'console.log(getComputedStyle(h1).color)' ; // Logs 'rgb(255, 0, 0)'
style. innerText = 'h1 {color: rgb(255, 0, 0);}' ;
document. body. append( fragment);
上例中的脚本记录了
,因为以下事件按顺序发生:
规范也可以为所有或某些节点定义连接后步骤。该算法传递connectedNode,如下面的插入算法所示。
连接后步骤的目的是为节点提供机会执行任何与连接相关的操作,这些操作会修改connectedNode参与的节点树,创建浏览上下文,或执行其他 JavaScript。这些步骤允许一批节点相对于脚本原子地插入,所有主要的副作用都在批量插入到节点树完成后发生。这确保了所有待处理的节点树插入完全完成后才会发生更多的插入。
规范可以为所有或某些节点定义子节点变化步骤。该算法不传递参数,并在插入、移除和替换数据时调用。
要将节点插入到父节点中的子节点之前,并带有一个可选的抑制观察者标志,请运行以下步骤:
-
如果节点是
DocumentFragment
节点,则将节点的子节点赋值给nodes;否则赋值«节点»。 -
将nodes的大小赋值给count。
-
如果count为0,则返回。
-
如果节点是
DocumentFragment
节点,则:-
为节点排队一个树变更记录,包含«»、nodes、null和null。
此步骤有意不关注抑制观察者标志。
-
如果子节点非空,则:
-
对于nodes中的每个节点,按树顺序:
-
对于节点的每个包括阴影的包容性后代inclusiveDescendant,按包括阴影的树顺序:
-
如果抑制观察者标志未设置,则为父节点排队一个树变更记录,包含nodes、«»、previousSibling和子节点。
-
运行子节点变化步骤,针对父节点。
-
将staticNodeList设置为列表,包含节点,初始值为«»。
我们在调用任何一个节点的连接后步骤之前收集所有节点,而不是在遍历节点树时调用连接后步骤。这是因为连接后步骤可能会修改树的结构,使实时遍历不安全,可能导致在同一个节点上多次调用连接后步骤。
-
对于nodes中的每个节点,按树顺序:
-
对于节点的每个包括阴影的包容性后代inclusiveDescendant,按包括阴影的树顺序,将inclusiveDescendant追加到staticNodeList。
-
要将节点追加到父节点,请将节点预插入到父节点的空之前。
要用节点替换父节点内的子节点,请运行以下步骤:
-
如果父节点不是
Document
、DocumentFragment
或Element
节点,则抛出一个"HierarchyRequestError
"DOMException
。 -
如果节点是父节点的包含宿主的包容性祖先,则抛出一个"
HierarchyRequestError
"DOMException
。 -
如果子节点的父节点不是父节点,则抛出一个"
NotFoundError
"DOMException
。 -
如果节点不是
DocumentFragment
、DocumentType
、Element
或CharacterData
节点,则抛出一个"HierarchyRequestError
"DOMException
。 -
如果节点是文档,或文档类型,则抛出一个"
HierarchyRequestError
"DOMException
。 -
如果父节点是文档,并且下面的某些语句为真,则抛出一个"
HierarchyRequestError
"DOMException
。上面的语句与预插入算法不同。
-
将referenceChild赋值为子节点的下一个兄弟节点。
-
如果referenceChild是节点,则将referenceChild设置为节点的下一个兄弟节点。
-
将previousSibling赋值为子节点的前一个兄弟节点。
-
将removedNodes赋值为空集。
-
如果子节点的父节点非空,则:
-
将removedNodes设置为«子节点»。
-
移除子节点并设置抑制观察者标志。
上面的情况只有在子节点是节点时为假。
-
-
如果节点是
DocumentFragment
节点,则将节点的子节点赋值给nodes;否则赋值«节点»。 -
插入节点到父节点中,位于referenceChild之前,并设置抑制观察者标志。
-
为父节点排队一个树变更记录,包含nodes、removedNodes、previousSibling和referenceChild。
-
返回子节点。
要在父节点内用节点替换全部,请运行以下步骤:
-
将removedNodes设置为父节点的子节点。
-
将addedNodes设置为空集。
-
如果节点是
DocumentFragment
节点,则将节点的子节点赋值给addedNodes。 -
否则,如果节点非空,将addedNodes设置为«节点»。
-
如果节点非空,则将节点插入到父节点中的空之前,并设置抑制观察者标志。
-
如果addedNodes或removedNodes非空,则为父节点排队一个树变更记录,包含addedNodes、removedNodes、null和null。
该算法不对节点树约束进行任何检查。规范作者需要明智地使用它。
要从父节点中预先移除子节点,请运行以下步骤:
-
如果子节点的父节点不是父节点,则抛出一个"
NotFoundError
"DOMException
。 -
移除子节点。
-
返回子节点。
规范可以为所有或某些节点定义移除步骤。该算法传递节点removedNode和节点-或-nulloldParent,如下面的移除算法所示。
要移除节点节点,并带有一个可选的抑制观察者标志,请运行以下步骤:
-
将父节点赋值为节点的父节点。
-
断言:父节点非空。
-
将索引赋值为节点的索引。
-
对于每个
NodeIterator
对象迭代器,其根的节点文档是节点的节点文档,运行NodeIterator
预移除步骤,给定节点和迭代器。 -
将oldPreviousSibling设置为节点的前一个兄弟节点。
-
将oldNextSibling设置为节点的下一个兄弟节点。
-
使用节点和父节点运行移除步骤。
-
将isParentConnected设置为父节点的已连接。
-
如果节点是自定义元素,并且isParentConnected为真,则为节点排队一个自定义元素回调反应,回调名称为"
disconnectedCallback
",参数列表为空。 -
对于父节点的每个包容性祖先inclusiveAncestor,然后对于inclusiveAncestor的已注册观察者列表中的每个registered,如果registered的选项["
subtree
"]为真,则将新的临时已注册观察者追加到节点的已注册观察者列表中。 -
如果抑制观察者标志未设置,则为父节点排队一个树变更记录,包含«»、«节点»、oldPreviousSibling和oldNextSibling。
-
运行子节点变化步骤,针对父节点。
4.2.4.
混入 NonElementParentNode
Web 兼容性阻止了 getElementById()
方法在元素上暴露(因此也不会暴露在ParentNode
上)。
interface mixin {
NonElementParentNode Element ?getElementById (DOMString ); };
elementId Document includes NonElementParentNode ;DocumentFragment includes NonElementParentNode ;
getElementById(elementId)
方法的步骤是返回 元素中第一个,其在树顺序中位于 this 的 后代中,且其 ID 为
elementId;否则,如果没有这样的元素,则返回 null。
ParentNode
要将节点转换为一个节点, 给定nodes和document, 按以下步骤执行:
-
让node为null。
-
如果nodes包含一个节点, 则将node设置为nodes[0]。
-
否则, 将node设置为一个新的
DocumentFragment
节点, 其节点文档为document, 然后追加每个nodes中的节点, 如果有的话,至该节点。 -
返回node。
interface mixin { [
ParentNode SameObject ]readonly attribute HTMLCollection children ;readonly attribute Element ?firstElementChild ;readonly attribute Element ?lastElementChild ;readonly attribute unsigned long childElementCount ; [CEReactions ,Unscopable ]undefined prepend ((Node or TrustedScript or DOMString )...); [
nodes CEReactions ,Unscopable ]undefined append ((Node or TrustedScript or DOMString )...); [
nodes CEReactions ,Unscopable ]undefined replaceChildren ((Node or TrustedScript or DOMString )...);
nodes Element ?querySelector (DOMString ); [
selectors NewObject ]NodeList querySelectorAll (DOMString ); };
selectors Document includes ParentNode ;DocumentFragment includes ParentNode ;Element includes ParentNode ;
collection=node.
children
- 返回 子元素。
element=node.
firstElementChild
- 返回第一个 子是元素;否则返回 null。
element=node.
lastElementChild
- 返回最后一个 子是元素;否则返回 null。
node. prepend(nodes)
-
在 node 的第一个 子节点之前插入 nodes,同时将字符串替换为等效的
Text
节点。抛出"
HierarchyRequestError
"DOMException
,如果违反了 节点树的约束。 node. append(nodes)
-
在 node 的最后一个 子节点之后插入 nodes,同时将字符串替换为等效的
Text
节点。抛出"
HierarchyRequestError
"DOMException
,如果违反了 节点树的约束。 node. replaceChildren(nodes)
-
用 nodes 替换 node 的所有 子节点,同时将字符串替换为等效的
Text
节点。抛出"
HierarchyRequestError
"DOMException
,如果违反了 节点树的约束。 node. querySelector(selectors)
node. querySelectorAll(selectors)
children
获取器步骤是返回一个 HTMLCollection
集合,该集合以 此为根,只匹配元素子节点。
firstElementChild
获取器步骤是返回
第一个 子节点,该子节点是元素;
否则返回 null。
lastElementChild
获取器步骤是返回
最后一个子节点,该子节点是元素;
否则返回 null。
childElementCount
获取器步骤是返回
子节点的数量,此只包含元素。
prepend(nodes)
方法的步骤为:
append(nodes)
方法的步骤为:
replaceChildren(nodes)
方法的步骤为:
querySelector(selectors)
方法的步骤是返回第一个运行范围匹配选择器字符串的结果,给定selectors,针对此,
如果结果不是空列表,则返回结果;
否则为null。
querySelectorAll(selectors)
方法的步骤是返回运行范围匹配选择器字符串的静态结果,给定selectors,针对此。
4.2.7. 混入 NonDocumentTypeChildNode
Web 兼容性阻止了 previousElementSibling
和
nextElementSibling
属性
在文档类型上公开(因此在 ChildNode
上也不会公开)。
interface mixin {
NonDocumentTypeChildNode readonly attribute Element ?previousElementSibling ;readonly attribute Element ?nextElementSibling ; };Element includes NonDocumentTypeChildNode ;CharacterData includes NonDocumentTypeChildNode ;
element=node.
previousElementSibling
- 返回第一个 前面的兄弟,该兄弟是元素;否则返回 null。
element=node.
nextElementSibling
- 返回第一个 后面的兄弟,该兄弟是元素;否则返回 null。
previousElementSibling
获取器步骤是返回第一个
前面的兄弟,该兄弟是元素;
否则返回 null。
nextElementSibling
获取器步骤是返回第一个 后面的兄弟,该兄弟是元素;
否则返回 null。
4.2.8.
混入 ChildNode
interface mixin { [
ChildNode CEReactions ,Unscopable ]undefined before ((Node or DOMString )...); [
nodes CEReactions ,Unscopable ]undefined after ((Node or DOMString )...); [
nodes CEReactions ,Unscopable ]undefined replaceWith ((Node or DOMString )...); [
nodes CEReactions ,Unscopable ]undefined remove (); };DocumentType includes ChildNode ;Element includes ChildNode ;CharacterData includes ChildNode ;
node.
before(...nodes)
-
在node之前插入nodes, 同时将nodes中的字符串替换为等效的
Text
节点。抛出 "
HierarchyRequestError
"DOMException
如果违反了 节点树的约束。 node.
after(...nodes)
-
在node之后插入nodes, 同时将nodes中的字符串替换为等效的
Text
节点。抛出 "
HierarchyRequestError
"DOMException
如果违反了 节点树的约束。 node.
replaceWith(...nodes)
-
用nodes替换node, 同时将nodes中的字符串替换为等效的
Text
节点。抛出 "
HierarchyRequestError
"DOMException
如果违反了 节点树的约束。 node.
remove()
- 移除node。
before(nodes)
方法的步骤为:
-
如果parent为 null,则返回。
-
如果viablePreviousSibling为 null,则将其设置为parent的第一个子节点;否则将其设置为viablePreviousSibling的下一个兄弟节点。
-
预插入node至parent,在viablePreviousSibling之前。
after(nodes)
方法的步骤为:
-
如果parent为 null,则返回。
-
预插入node至parent,在viableNextSibling之前。
replaceWith(nodes)
方法的步骤为:
-
如果parent为 null,则返回。
-
如果此的父节点为parent, 则替换此为node在parent内。
此可能已被插入node。
-
否则, 预插入node至parent,在viableNextSibling之前。
remove()
方法的步骤为:
4.2.9. 混入 Slottable
interface mixin {
Slottable readonly attribute HTMLSlotElement ?assignedSlot ; };Element includes Slottable ;Text includes Slottable ;
assignedSlot
获取器的步骤是返回给定查找插槽的结果,前提是设置了open flag。
4.2.10.
旧式集合:NodeList
和 HTMLCollection
集合是表示节点列表的对象。集合可以是实时集合或静态集合。除非另有说明,集合必须是实时集合。
如果集合是实时集合,那么该对象上的属性和方法必须操作实际的底层数据,而不是数据的快照。
当集合创建时,会与其关联一个过滤器和根。
然后,集合 表示以集合的根为根的子树的视图,仅包含符合给定过滤器的节点。该视图是线性的。在没有特定要求的情况下,集合中的节点必须按树顺序排序。
4.2.10.1.
接口 NodeList
[Exposed =Window ]interface {
NodeList getter Node ?item (unsigned long );
index readonly attribute unsigned long length ;iterable <Node >; };
- collection .
length
- 返回节点的数量,位于集合中。
- element = collection .
item(index)
- element = collection[index]
- 返回具有索引index的节点,来自集合中。这些节点按树顺序排序。
对象的支持的属性索引是从零到节点数量减一的范围内的数字由集合表示。如果没有这样的元素,那么就没有支持的属性索引。
length
属性必须返回由集合表示的节点数量。
item(index)
方法必须返回集合中第index个节点。如果集合中没有第index个节点,则该方法必须返回null。
4.2.10.2.
接口HTMLCollection
[Exposed =Window ,LegacyUnenumerableNamedProperties ]interface {
HTMLCollection readonly attribute unsigned long length ;getter Element ?item (unsigned long );
index getter Element ?(
namedItem DOMString ); };
name
HTMLCollection
对象是集合的一个元素。
HTMLCollection
是一个我们无法从网络中消除的历史遗留物。当然,开发人员可以继续使用它,但新API标准的设计者不应再使用它(在IDL中使用sequence<T>
代替)。
- collection .
length
- 返回元素的数量,位于集合中。
- element = collection .
item(index)
- element = collection[index]
- 返回集合中索引为index的元素。这些元素按树顺序排序。
- element = collection .
namedItem(name)
- element = collection[name]
- 返回集合中第一个具有ID或名称为name的元素。
对象的支持的属性索引是从零到元素数量减一的范围内的数字由集合表示。如果没有这样的元素,那么就没有支持的属性索引。
length
获取器步骤应返回由集合表示的节点数量。
item(index)
方法步骤应返回集合中第index个元素。如果集合中没有第index个元素,则该方法必须返回null。
支持的属性名称是通过以下步骤返回的列表中的值:
-
令result为一个空列表。
-
返回result。
namedItem(key)
方法步骤是:
4.3. Mutation observers
每个相同来源窗口代理都有一个突变观察者微任务排队(布尔值),其初始值为false。[HTML]
每个相同来源窗口代理还具有待处理的突变观察者(一个包含零个或多个MutationObserver
对象的集合),其初始状态为空。
要排队一个突变观察者微任务,请执行以下步骤:
-
如果周围代理的突变观察者微任务排队为true,则返回。
-
将周围代理的突变观察者微任务排队设置为true。
要通知突变观察者,请执行以下步骤:
-
将周围代理的突变观察者微任务排队设置为false。
-
对于notifySet中的每个mo:
-
对于signalSet中的每个slot,触发一个名为
slotchange
的事件,其bubbles
属性设置为true,在slot处。
每个节点都有一个注册观察者列表(一个包含零个或多个注册观察者的列表),其初始状态为空。
一个注册观察者由一个观察者(一个MutationObserver
对象)和选项(一个MutationObserverInit
字典)组成。
一个瞬态注册观察者是一个注册观察者,它还包括一个源(一个注册观察者)。
瞬态注册观察者用于跟踪给定节点的后代中的突变,在节点被移除后,以便在其父节点上将subtree
设置为true时,不会丢失这些突变。
4.3.1.
接口 MutationObserver
[Exposed =Window ]interface {
MutationObserver constructor (MutationCallback );
callback undefined observe (Node ,
target optional MutationObserverInit = {});
options undefined disconnect ();sequence <MutationRecord >takeRecords (); };callback =
MutationCallback undefined (sequence <MutationRecord >,
mutations MutationObserver );
observer dictionary {
MutationObserverInit boolean =
childList false ;boolean ;
attributes boolean ;
characterData boolean =
subtree false ;boolean ;
attributeOldValue boolean ;
characterDataOldValue sequence <DOMString >; };
attributeFilter
MutationObserver
对象可用于观察 节点 的 树 的变动。
每个 MutationObserver
对象有以下关联概念:
- 在创建时设置的 回调。
- 一个 节点列表(一个指向 节点 的弱引用的 列表),初始为空。
- 一个 记录队列(一个包含零个或多个
MutationRecord
对象的 队列),初始为空。
observer = new
MutationObserver(callback)
- 构造一个
MutationObserver
对象,并将其 回调 设置为 callback。在observe()
方法注册的 节点 变动后,调用 callback,传入一个MutationRecord
对象的列表作为第一个参数,并将构造的MutationObserver
对象作为第二个参数。 observer .
observe(target, options)
- 指示用户代理观察给定的 target(一个 节点)并根据 options(一个对象)提供的条件报告任何变动。
options 参数允许通过对象成员设置变动观察选项。以下是可以使用的对象成员:
childList
- 如果要观察 target 的 子节点 的变动,则设置为 true。
attributes
- 如果要观察 target 的 属性 的变动,则设置为 true。如果指定了
attributeOldValue
或attributeFilter
,则可以省略。 characterData
- 如果要观察 target 的 数据 的变动,则设置为 true。如果指定了
characterDataOldValue
,则可以省略。 subtree
- 如果要观察不仅是 target,而且还有 target 的 后代节点 的变动,则设置为 true。
attributeOldValue
- 如果
attributes
为 true 或省略,并且需要记录变动前 target 的 属性 值,则设置为 true。 characterDataOldValue
- 如果
characterData
设置为 true 或省略,并且需要记录变动前 target 的 数据,则设置为 true。 attributeFilter
- 如果不需要观察所有 属性 的变动,并且
attributes
为 true 或省略,则设置为 属性的本地名称(不包括 命名空间)的列表。
observer .
disconnect()
- 停止 observer 观察任何变动。在再次使用
observe()
方法之前,observer 的 回调 将不会被调用。 observer .
takeRecords()
- 清空 记录队列 并返回其中的内容。
new MutationObserver(callback)
构造函数的步骤是将 this 的
回调 设置为
callback。
observe(target, options)
方法的步骤如下:
-
如果 options["
attributeOldValue
"] 或 options["attributeFilter
"] 存在,且 options["attributes
"] 不 存在,则将 options["attributes
"] 设置为 true。 -
如果 options["
characterDataOldValue
"] 存在,且 options["characterData
"] 不 存在,则将 options["characterData
"] 设置为 true。 -
如果 options["
childList
"]、options["attributes
"] 和 options["characterData
"] 都不为 true,则 抛出TypeError
。 -
如果 options["
attributeOldValue
"] 为 true,而 options["attributes
"] 为 false,则 抛出TypeError
。 -
如果 options["
attributeFilter
"] 存在,而 options["attributes
"] 为 false,则 抛出TypeError
。 -
如果 options["
characterDataOldValue
"] 为 true,而 options["characterData
"] 为 false,则 抛出TypeError
。 -
对于 target 的 注册观察者列表 中的每个 registered,如果 registered 的 观察者 是 this:
-
否则:
disconnect()
方法的步骤如下:
takeRecords()
方法的步骤如下:
4.3.2. 排队突变记录
要为 type、target、name、namespace、oldValue、addedNodes、removedNodes、previousSibling 和 nextSibling 排队一个突变记录,请执行以下步骤:
-
让 interestedObservers 成为一个空的 映射。
-
让 nodes 成为 target 的 包括的祖先。
-
对于 nodes 中的每个 node,然后 对每个 node 的 注册观察者列表 中的 registered:
-
让 options 成为 registered 的 选项。
-
如果以下条件都不成立
- node 不是 target 并且 options["
subtree
"] 为 false - type 是 "
attributes
" 并且 options["attributes
"] 不 存在 或为 false - type 是 "
attributes
",options["attributeFilter
"] 存在,并且 options["attributeFilter
"] 不 包含 name 或 namespace 非空 - type 是 "
characterData
" 并且 options["characterData
"] 不 存在 或为 false - type 是 "
childList
" 并且 options["childList
"] 为 false
则:
-
让 mo 成为 registered 的 观察者。
-
如果 interestedObservers[mo] 不 存在,则 将 interestedObservers[mo] 设置为 null。
-
如果 type 是 "
attributes
" 并且 options["attributeOldValue
"] 为 true,或 type 是 "characterData
" 并且 options["characterDataOldValue
"] 为 true,则 将 interestedObservers[mo] 设置为 oldValue。
- node 不是 target 并且 options["
-
-
对于 interestedObservers 中的每个 observer → mappedOldValue:
-
让 record 成为一个新的
MutationRecord
对象,其type
设置为 type,target
设置为 target,attributeName
设置为 name,attributeNamespace
设置为 namespace,oldValue
设置为 mappedOldValue,addedNodes
设置为 addedNodes,removedNodes
设置为 removedNodes,previousSibling
设置为 previousSibling,nextSibling
设置为 nextSibling。
-
要为 target 以及 addedNodes、removedNodes、previousSibling 和 nextSibling 排队一个树突变记录,请执行以下步骤:
-
断言:addedNodes 或 removedNodes 非空。
-
排队一个突变记录类型为 "
childList
",目标为 target,值为 null、null、null、addedNodes、removedNodes、previousSibling 和 nextSibling。
4.3.3.
接口 MutationRecord
[Exposed =Window ]interface {
MutationRecord readonly attribute DOMString type ; [SameObject ]readonly attribute Node target ; [SameObject ]readonly attribute NodeList addedNodes ; [SameObject ]readonly attribute NodeList removedNodes ;readonly attribute Node ?previousSibling ;readonly attribute Node ?nextSibling ;readonly attribute DOMString ?attributeName ;readonly attribute DOMString ?attributeNamespace ;readonly attribute DOMString ?oldValue ; };
record .
type
- 如果是 属性 突变,返回
"
attributes
"。 如果是CharacterData
节点 的突变,返回 "characterData
"。如果是 树 的 节点 突变,返回 "childList
"。 record .
target
- 返回突变影响的 节点,具体取决于
type
。 对于 "attributes
",返回其 元素 的 属性 发生了变化。对于 "characterData
",返回CharacterData
节点。对于 "childList
",返回其 子节点 发生变化的 节点。 record .
addedNodes
record .
removedNodes
- 分别返回添加和移除的 节点。
record .
previousSibling
record .
nextSibling
- 分别返回添加或移除的 节点 的 前一个 和 下一个 兄弟节点;否则返回 null。
record .
attributeName
- 返回已更改的 属性 的本地名称;否则返回 null。
record .
attributeNamespace
- 返回已更改的 属性的命名空间;否则返回 null。
record .
oldValue
- 返回值取决于
type
。 对于 "attributes
",返回更改前的 属性值。 对于 "characterData
",返回更改前的 节点数据。对于 "childList
",返回 null。
type
,target
,addedNodes
,removedNodes
,previousSibling
,nextSibling
,attributeName
,attributeNamespace
和 oldValue
属性必须返回其初始化时的值。
4.4. 接口 Node
[Exposed =Window ]interface :
Node EventTarget {const unsigned short ELEMENT_NODE = 1;const unsigned short ATTRIBUTE_NODE = 2;const unsigned short TEXT_NODE = 3;const unsigned short CDATA_SECTION_NODE = 4;const unsigned short = 5; // legacy
ENTITY_REFERENCE_NODE const unsigned short = 6; // legacy
ENTITY_NODE const unsigned short PROCESSING_INSTRUCTION_NODE = 7;const unsigned short COMMENT_NODE = 8;const unsigned short DOCUMENT_NODE = 9;const unsigned short DOCUMENT_TYPE_NODE = 10;const unsigned short DOCUMENT_FRAGMENT_NODE = 11;const unsigned short = 12; // legacy
NOTATION_NODE readonly attribute unsigned short nodeType ;readonly attribute DOMString nodeName ;readonly attribute USVString baseURI ;readonly attribute boolean isConnected ;readonly attribute Document ?ownerDocument ;Node getRootNode (optional GetRootNodeOptions = {});
options readonly attribute Node ?parentNode ;readonly attribute Element ?parentElement ;boolean hasChildNodes (); [SameObject ]readonly attribute NodeList childNodes ;readonly attribute Node ?firstChild ;readonly attribute Node ?lastChild ;readonly attribute Node ?previousSibling ;readonly attribute Node ?nextSibling ; [CEReactions ]attribute DOMString ?nodeValue ; [CEReactions ]attribute DOMString ?textContent ; [CEReactions ]undefined normalize (); [CEReactions ,NewObject ]Node cloneNode (optional boolean =
deep false );boolean isEqualNode (Node ?);
otherNode boolean isSameNode (Node ?); // legacy alias of ===
otherNode const unsigned short DOCUMENT_POSITION_DISCONNECTED = 0x01;const unsigned short DOCUMENT_POSITION_PRECEDING = 0x02;const unsigned short DOCUMENT_POSITION_FOLLOWING = 0x04;const unsigned short DOCUMENT_POSITION_CONTAINS = 0x08;const unsigned short DOCUMENT_POSITION_CONTAINED_BY = 0x10;const unsigned short DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC = 0x20;unsigned short compareDocumentPosition (Node );
other boolean contains (Node ?);
other DOMString ?lookupPrefix (DOMString ?);
namespace DOMString ?lookupNamespaceURI (DOMString ?);
prefix boolean isDefaultNamespace (DOMString ?); [
namespace CEReactions ]Node insertBefore (Node ,
node Node ?); [
child CEReactions ]Node appendChild (Node ); [
node CEReactions ]Node replaceChild (Node ,
node Node ); [
child CEReactions ]Node removeChild (Node ); };
child dictionary {
GetRootNodeOptions boolean =
composed false ; };
Node
是一个用于所有节点的抽象接口。你不能直接获取它的实例。
给定一个event时,节点的get the parent 算法返回已分配插槽,如果节点被分配了;否则,返回父节点。
node .
nodeType
-
返回一个与node类型相对应的数字,如下所示:
Element
(1)。Node
.ELEMENT_NODE
Attr
(2)。Node
.ATTRIBUTE_NODE
- 一个独占的
Text
节点
(3)。Node
.TEXT_NODE
CDATASection
(4)。Node
.CDATA_SECTION_NODE
ProcessingInstruction
(7)。Node
.PROCESSING_INSTRUCTION_NODE
Comment
(8)。Node
.COMMENT_NODE
Document
(9)。Node
.DOCUMENT_NODE
DocumentType
(10)。Node
.DOCUMENT_TYPE_NODE
DocumentFragment
(11)。Node
.DOCUMENT_FRAGMENT_NODE
node .
nodeName
-
返回一个与node类型相对应的字符串,如下所示:
Element
- 它的HTML大写的限定名称。
Attr
- 它的限定名称。
- 一个独占的
Text
节点 - "
#text
"。 CDATASection
- "
#cdata-section
"。 ProcessingInstruction
- 它的目标。
Comment
- "
#comment
"。 Document
- "
#document
"。 DocumentType
- 它的名称。
DocumentFragment
- "
#document-fragment
"。
nodeType
的 getter 步骤是返回第一个匹配的语句,切换接口 this implements:
Element
ELEMENT_NODE
(1)Attr
ATTRIBUTE_NODE
(2);- 一个 独占
Text
节点 TEXT_NODE
(3);CDATASection
CDATA_SECTION_NODE
(4);ProcessingInstruction
PROCESSING_INSTRUCTION_NODE
(7);Comment
COMMENT_NODE
(8);Document
DOCUMENT_NODE
(9);DocumentType
DOCUMENT_TYPE_NODE
(10);DocumentFragment
DOCUMENT_FRAGMENT_NODE
(11).
nodeName
的 getter 步骤是返回第一个匹配的语句,切换接口 this implements:
Element
- 它的 HTML 大写限定名称。
Attr
- 它的 限定名称。
- 一个 独占
Text
节点 - "
#text
"。 CDATASection
- "
#cdata-section
"。 ProcessingInstruction
- 它的 目标。
Comment
- "
#comment
"。 Document
- "
#document
"。 DocumentType
- 它的 名称。
DocumentFragment
- "
#document-fragment
"。
node .
baseURI
- 返回 node 的 节点文档的 文档基础 URL。
baseURI
的 getter 步骤是返回 this 的 节点文档的 文档基础 URL,并且序列化。
node .
isConnected
-
如果 node 是连接的,则返回 true;否则返回 false。
node .
ownerDocument
- 返回 node document。 对于文档,返回 null。
node .
getRootNode()
- 返回 node 的根。
node . getRootNode({ composed:true })
- 返回 node 的包含 shadow 的根。
node .
parentNode
- 返回父节点。
node .
parentElement
- 返回父元素。
node .
hasChildNodes()
- 返回 node 是否有子节点。
node .
childNodes
- 返回子节点。
node .
firstChild
- 返回第一个子节点。
node .
lastChild
- 返回最后一个子节点。
node .
previousSibling
- 返回前一个兄弟节点。
node .
nextSibling
- 返回下一个兄弟节点。
isConnected
的 getter 步骤是如果 this 是连接的,则返回 true;否则返回 false。
ownerDocument
的 getter 步骤是如果 this 是文档,则返回 null;否则返回 this 的 节点文档。
一个 文档 的 节点文档 就是该 文档 本身。所有 节点始终都有一个 节点文档。
getRootNode(options)
方法步骤是如果
options["composed
"]
为 true,则返回 this
的 包括影子的根;否则返回 this 的 根。
parentNode
的 getter 步骤是返回 this 的 父级。
parentElement
的 getter 步骤是返回 this 的 父元素。
hasChildNodes()
方法步骤是如果 this 有 子节点,则返回 true;否则返回 false。
childNodes
的 getter 步骤是返回一个 NodeList
,其根位于
this 处,仅匹配
子节点。
firstChild
的 getter 步骤是返回 this 的 第一个子节点。
lastChild
的 getter 步骤是返回 this 的 最后一个子节点。
previousSibling
的 getter 步骤是返回 this 的 上一个兄弟节点。
nextSibling
的 getter 步骤是返回 this 的 下一个兄弟节点。
nodeValue
的 getter 步骤是返回以下内容,切换接口 this implements:
Attr
- this 的 值。
CharacterData
- this 的 数据。
- 否则
- Null。
nodeValue
的 setter 步骤是,如果给定的值为 null,则将其视为空字符串,然后按以下描述执行,切换接口 this implements:
要获取文本内容,使用 节点 node,返回以下内容,切换接口 node implements:
DocumentFragment
Element
- node 的后代文本内容。
Attr
- node 的 值。
CharacterData
- node 的 数据。
- 否则
- Null。
textContent
的 getter 步骤是返回运行 获取文本内容 的结果,使用 this。
要字符串替换全部,使用一个字符串 string 在 节点 parent 内,运行以下步骤:
-
令 node 为 null。
-
如果 string 不是空字符串,则将 node 设置为一个新的
Text
节点,其 数据为 string,节点文档为 parent 的 节点文档。 -
全部替换,使用 node 在 parent 内。
要设置文本内容,使用一个 节点 node 和一个字符串 value,按下述定义操作,切换接口 node implements:
DocumentFragment
Element
-
字符串替换全部,使用 value 在 node 内。
Attr
-
设置现有属性值,使用 node 和 value。
CharacterData
- 否则
-
什么也不做。
textContent
的 setter 步骤是,如果给定的值为 null,则将其视为空字符串,然后运行 设置文本内容,使用 this 和给定的值。
node .
normalize()
- 移除 空 的 独占
Text
节点,并将剩余 数据连接到它们的第一个 节点中。
方法 normalize()
的步骤是针对 后代 独占
Text
节点 node 运行这些步骤:
- 令 length 为 node 的 长度。
- 如果 length 为零,则 移除 node 并继续下一个 独占
Text
节点(如果有的话)。 - 令 data 为 node 的 数据与其 连续的独占
Text
节点(不包括其自身)的 连接,按 树顺序。 - 用节点 node,偏移量 length,计数 0 和数据 data 替换数据。
- 令 currentNode 为 node 的 下一个兄弟节点。
-
当 currentNode 是一个 独占
Text
节点 时:-
对于起始节点是 currentNode 的每个 活动范围,将 length 加到其 起始偏移量 并将其 起始节点 设置为 node。
-
对于结束节点是 currentNode 的每个 活动范围,将 length 加到其 结束偏移量 并将其 结束节点 设置为 node。
-
对于起始节点是 currentNode 的 父级且起始偏移量是 currentNode 的 索引 的每个活动范围,将其起始节点设置为 node,并将其起始偏移量设置为 length。
-
对于结束节点是 currentNode 的 父级且结束偏移量是 currentNode 的 索引 的每个活动范围,将其结束节点设置为 node,并将其结束偏移量设置为 length。
-
将 currentNode 的 长度 加到 length 中。
-
将 currentNode 设置为其下一个兄弟节点。
-
- 移除 node 的 连续独占
Text
节点(不包括其自身),按树顺序。
node . cloneNode([deep = false])
- 返回 node 的副本。如果 deep 为 true,副本还包括 node 的 后代。
node .
isEqualNode(otherNode)
- 返回 node 和 otherNode 是否具有相同的属性。
规范可能会为所有或部分 节点定义克隆步骤。该算法会传递 copy、node、document 和一个可选的克隆子节点标志,如在 克隆算法中所指示的。
HTML 为
script
和input
元素定义了克隆步骤。SVG
也应为其script
元素做同样的事情,但目前尚未提到。
要克隆一个node,可选地带上document和克隆子节点标志,请运行以下步骤:
-
如果没有给出document,则令document为node的节点文档。
-
如果node是一个元素,则:
-
设置copy的节点文档和document为copy,如果copy是一个文档,否则将copy的节点文档设置为document。
-
运行任何在其他适用规范中为node定义的克隆步骤,并传递copy、node、document,以及如果设置了克隆子节点标志,则将其作为参数。
-
如果设置了克隆子节点标志,则对于node的每个子节点,按树顺序:将克隆子节点的结果(带有document和克隆子节点标志设置)附加到copy。
-
返回copy。
方法cloneNode(deep)
的步骤如下:
-
如果this是一个影根,则抛出"
NotSupportedError
"DOMException
。
方法isEqualNode(otherNode)
的步骤是:如果otherNode非空并且this等于otherNode,则返回 true;否则返回 false。
方法isSameNode(otherNode)
的步骤是:如果otherNode是this,则返回
true;否则返回 false。
node .
compareDocumentPosition(other)
-
返回一个位掩码,指示other相对于node的位置。可以设置以下位:
(1)Node
.DOCUMENT_POSITION_DISCONNECTED
- 当node和other不在同一树中时设置。
(2)Node
.DOCUMENT_POSITION_PRECEDING
- 当other在node之前preceding时设置。
(4)Node
.DOCUMENT_POSITION_FOLLOWING
- 当other在node之后following时设置。
(8)Node
.DOCUMENT_POSITION_CONTAINS
- 当other是node的祖先时设置。
(16, 16 的十六进制表示为 10)Node
.DOCUMENT_POSITION_CONTAINED_BY
- 当other是node的后代时设置。
node .
contains(other)
- 如果other是node的包容后代,则返回 true;否则返回 false。
以下是compareDocumentPosition()
返回的掩码常量:
DOCUMENT_POSITION_DISCONNECTED
(1);DOCUMENT_POSITION_PRECEDING
(2);DOCUMENT_POSITION_FOLLOWING
(4);DOCUMENT_POSITION_CONTAINS
(8);DOCUMENT_POSITION_CONTAINED_BY
(16, 16 的十六进制表示为 10);DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC
(32, 32 的十六进制表示为 20)。
方法compareDocumentPosition(other)
的步骤如下:
-
如果this是other,则返回零。
-
将node1设为other,node2设为this。
-
将attr1和attr2设为 null。
-
如果node2是一个属性,则:
-
将attr2设为node2,并将node2设为attr2的元素。
-
如果attr1和node1非空,且node2为node1,则:
-
-
如果attr等于attr1,则返回
DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC
和DOCUMENT_POSITION_PRECEDING
之和。 -
如果attr等于attr2,则返回
DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC
和DOCUMENT_POSITION_FOLLOWING
之和。
-
-
-
-
如果node1或node2为 null,或者node1的根与node2的根不同,则返回
DOCUMENT_POSITION_DISCONNECTED
、DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC
,以及DOCUMENT_POSITION_PRECEDING
或DOCUMENT_POSITION_FOLLOWING
之和,确保返回值一致。是否返回
DOCUMENT_POSITION_PRECEDING
或DOCUMENT_POSITION_FOLLOWING
通常是通过指针比较实现的。在JavaScript实现中,可以使用缓存的Math.random()
值。 -
如果node1是node2的祖先,并且attr1为 null,或node1是node2且attr2非空,则返回
DOCUMENT_POSITION_CONTAINS
和DOCUMENT_POSITION_PRECEDING
之和。 -
如果node1是node2的后代,并且attr2为 null,或node1是node2且attr1非空,则返回
DOCUMENT_POSITION_CONTAINED_BY
和DOCUMENT_POSITION_FOLLOWING
之和。 -
如果node1在node2之前preceding,则返回
DOCUMENT_POSITION_PRECEDING
。
方法contains(other)
的步骤是:如果other是包容后代,则返回 true;否则(包括other为 null 时)返回
false。
要为一个使用namespace的element 定位命名空间前缀,请执行以下步骤:
要为一个node使用prefix 定位命名空间,请根据node 实现的接口进行切换:
Element
Document
DocumentType
DocumentFragment
-
返回 null。
Attr
- 否则
方法lookupPrefix(namespace)
的步骤如下:
-
如果 namespace 为 null 或空字符串,则返回 null。
方法lookupNamespaceURI(prefix)
的步骤如下:
方法isDefaultNamespace(namespace)
的步骤如下:
-
如果namespace是空字符串,则将其设置为 null。
-
如果defaultNamespace与namespace相同,则返回 true;否则返回 false。
方法insertBefore(node, child)
的步骤是返回将node插入到this之前child的预插入结果。
方法appendChild(node)
的步骤是返回将node追加到this的追加结果。
方法replaceChild(node, child)
的步骤是返回在this内用node替换child的结果。
方法removeChild(child)
的步骤是返回从this中预删除child的结果。
对于root的节点具有限定名称qualifiedName的元素列表是通过以下算法返回的HTMLCollection
:
-
如果qualifiedName是U+002A (*),则返回一个根为root的
HTMLCollection
,其过滤器仅匹配后代元素。 -
否则,如果root的节点文档是一个HTML 文档,则返回一个根为root的
HTMLCollection
,其过滤器匹配以下后代元素: -
否则,返回一个根为root的
HTMLCollection
,其过滤器匹配后代元素,其限定名称为qualifiedName。
当使用相同参数调用时,只要root的节点文档的类型未更改,可能会返回与之前调用返回的相同的HTMLCollection
对象。
对于root的节点具有命名空间namespace和本地名称localName的元素列表是通过以下算法返回的HTMLCollection
:
-
如果namespace是空字符串,则将其设置为 null。
-
如果namespace和localName均为 U+002A (*),则返回一个根为root的
HTMLCollection
,其过滤器匹配后代元素。 -
如果namespace是U+002A (*),则返回一个根为root的
HTMLCollection
,其过滤器匹配后代元素,其本地名称为localName。 -
如果localName是U+002A (*),则返回一个根为root的
HTMLCollection
,其过滤器匹配后代元素,其命名空间为namespace。 -
返回一个根为root的
HTMLCollection
,其过滤器匹配后代元素,其命名空间为namespace且本地名称为localName。
当使用相同参数调用时,可能会返回与之前调用返回的相同的HTMLCollection
对象。
对于root的节点具有类名classNames的元素列表是通过以下算法返回的HTMLCollection
:
- 令classes为在classNames上运行有序集解析器的结果。
- 如果classes为空集,则返回一个空的
HTMLCollection
。 -
返回一个根为root的
HTMLCollection
,其过滤器匹配后代元素,这些元素的所有类都在classes中。对于类的比较,如果root的节点文档的模式为"
quirks
",则必须以ASCII 大小写不敏感的方式进行比较;否则以相同的方式进行比较。
当使用相同参数调用时,可能会返回与之前调用返回的相同的HTMLCollection
对象。
4.5. 接口 Document
[Exposed =Window ]interface :
Document Node {constructor (); [SameObject ]readonly attribute DOMImplementation implementation ;readonly attribute USVString URL ;readonly attribute USVString documentURI ;readonly attribute DOMString compatMode ;readonly attribute DOMString characterSet ;readonly attribute DOMString charset ; // legacy alias of .characterSetreadonly attribute DOMString inputEncoding ; // legacy alias of .characterSetreadonly attribute DOMString contentType ;readonly attribute DocumentType ?doctype ;readonly attribute Element ?documentElement ;HTMLCollection getElementsByTagName (DOMString );
qualifiedName HTMLCollection getElementsByTagNameNS (DOMString ?,
namespace DOMString );
localName HTMLCollection getElementsByClassName (DOMString ); [
classNames CEReactions ,NewObject ]Element createElement (DOMString ,
localName optional (DOMString or ElementCreationOptions )= {}); [
options CEReactions ,NewObject ]Element createElementNS (DOMString ?,
namespace DOMString ,
qualifiedName optional (DOMString or ElementCreationOptions )= {}); [
options NewObject ]DocumentFragment createDocumentFragment (); [NewObject ]Text createTextNode (DOMString ); [
data NewObject ]CDATASection createCDATASection (DOMString ); [
data NewObject ]Comment createComment (DOMString ); [
data NewObject ]ProcessingInstruction createProcessingInstruction (DOMString ,
target DOMString ); [
data CEReactions ,NewObject ]Node importNode (Node ,
node optional boolean =
deep false ); [CEReactions ]Node adoptNode (Node ); [
node NewObject ]Attr createAttribute (DOMString ); [
localName NewObject ]Attr createAttributeNS (DOMString ?,
namespace DOMString ); [
qualifiedName NewObject ]Event createEvent (DOMString ); // legacy [
interface NewObject ]Range createRange (); // NodeFilter.SHOW_ALL = 0xFFFFFFFF [NewObject ]NodeIterator createNodeIterator (Node ,
root optional unsigned long = 0xFFFFFFFF,
whatToShow optional NodeFilter ?=
filter null ); [NewObject ]TreeWalker createTreeWalker (Node ,
root optional unsigned long = 0xFFFFFFFF,
whatToShow optional NodeFilter ?=
filter null ); }; [Exposed =Window ]interface :
XMLDocument Document {};dictionary {
ElementCreationOptions DOMString ; };
is
每个文档都有一个关联的编码(一个编码)、内容类型(一个字符串)、URL(一个URL)、来源(一个来源)、类型("xml
"或"html
")、模式("no-quirks
"、"quirks
"或"limited-quirks
")和允许声明性影子根(一个布尔值)。[编码][URL][HTML]
除非另有说明,否则文档的编码是utf-8 编码,内容类型是"application/xml
",URL是"about:blank
",来源是不透明来源,类型是"xml
",模式是"no-quirks
",并且允许声明性影子根为假。
文档被称为XML文档,如果其类型是"xml
";否则称为HTML文档。文档是HTML文档还是XML文档会影响某些API的行为。
文档被称为无怪癖模式,如果其模式是"no-quirks
",怪癖模式,如果其模式是"quirks
",以及有限怪癖模式,如果其模式是"limited-quirks
"。
模式只有在以下情况下才会从默认值更改:由文档的HTML解析器根据DOCTYPE字符串的存在、缺失或值创建,或由新浏览上下文(初始"about:blank
")创建时。[HTML]
无怪癖模式最初被称为“标准模式”,有限怪癖模式曾被称为“几乎标准模式”。它们被重命名是因为它们的细节现在由标准定义。(并且因为Ian Hickson以这些名字是荒谬的为理由否决了它们的原始名字。)
文档的获取父级算法在给定一个事件的情况下,如果事件的类型
属性值是"load
"或文档没有浏览上下文,则返回null;否则返回文档的相关全局对象。
- document .
doctype
- 返回 doctype,如果没有则返回 null。
- document .
documentElement
- 返回 document element。
- collection = document .
getElementsByTagName(qualifiedName)
-
如果 qualifiedName 是 "
*
",则返回一个包含所有 后代 元素 的HTMLCollection
。否则,返回一个包含所有 后代 元素 的
HTMLCollection
,其 限定名 为 qualifiedName。(在 HTML 命名空间中的 HTML 文档中,对 元素 进行不区分大小写的匹配。) - collection = document .
getElementsByTagNameNS(namespace, localName)
-
如果 namespace 和 localName 都是 "
*
",则返回一个包含所有 后代 元素 的HTMLCollection
。如果只有 namespace 是 "
*
",则返回一个包含所有 后代 元素 的HTMLCollection
,其 本地名 为 localName。如果只有 localName 是 "
*
",则返回一个包含所有 后代 元素 的HTMLCollection
,其 命名空间 为 namespace。否则,返回一个包含所有 后代 元素 的
HTMLCollection
,其 命名空间 为 namespace,且 本地名 为 localName。 - collection = document .
getElementsByClassName(classNames)
- collection = element .
getElementsByClassName(classNames)
-
返回在调用该方法的对象(一个 文档 或一个 元素)中具有所有由 classNames 指定的类的 元素 的
HTMLCollection
。classNames 参数被解释为以空格分隔的类列表。
doctype
的 getter 步骤是返回 this 的一个 doctype 子节点;否则返回 null。
documentElement
的 getter 步骤是返回 this 的 document element。
getElementsByTagName(qualifiedName)
方法的步骤是返回 具有限定名 qualifiedName 的元素列表,用于 this。
因此,在 HTML
文档中,document.getElementsByTagName("FOO")
将匹配不在 HTML 命名空间中的 <FOO>
元素,以及在 HTML 命名空间中的
<foo>
元素,但不会匹配在 HTML 命名空间中的
<FOO>
元素。
getElementsByTagNameNS(namespace, localName)
方法的步骤是返回 具有命名空间 namespace 和本地名 localName
的元素列表,用于 this。
getElementsByClassName(classNames)
方法的步骤是返回 具有类名 classNames 的元素列表,用于 this。
< div id = "example" >
< p id = "p1" class = "aaa bbb" />
< p id = "p2" class = "aaa ccc" />
< p id = "p3" class = "bbb ccc" />
</ div >
调用document
将返回一个包含两个段落p1
和p2
的HTMLCollection
。
调用getElementsByClassName
将只返回一个节点,即p3
。调用document
将返回相同的内容。
调用getElementsByClassName
将不会返回任何节点;上面的元素中没有一个属于aaa,bbb
类。
element = document . createElement(localName [, options])
-
返回一个localName为本地名称的元素(如果document是HTML文档,则localName将小写)。元素的命名空间在document是HTML文档或document的内容类型为"
application/xhtml+xml
"时为HTML命名空间;否则为null。如果localName不匹配
名称
的生成,则会抛出一个"InvalidCharacterError
"DOMException
。 element = document . createElementNS(namespace, qualifiedName [, options])
-
返回一个具有namespace的元素。它的命名空间前缀将是qualifiedName中U+003A (:)之前的所有内容,否则为null。它的本地名称将是qualifiedName中U+003A (:)之后的所有内容,或者是qualifiedName。
如果qualifiedName不匹配
QName
的生成,则会抛出一个"InvalidCharacterError
"DOMException
。如果以下条件之一为真,则会抛出一个"
NamespaceError
"DOMException
: documentFragment = document .
createDocumentFragment()
- 返回一个
DocumentFragment
节点。 text = document .
createTextNode(data)
- 返回一个
Text
节点,其数据为data。 text = document .
createCDATASection(data)
- 返回一个
CDATASection
节点,其数据为data。 comment = document .
createComment(data)
- 返回一个
Comment
节点,其数据为data。 processingInstruction = document .
createProcessingInstruction(target, data)
- 返回一个
ProcessingInstruction
节点,其目标为target,数据为data。如果target不匹配名称
的生成,则会抛出一个"InvalidCharacterError
"DOMException
。如果data包含"?>
",则会抛出一个"InvalidCharacterError
"DOMException
。
元素接口对于任何名称和命名空间都是Element
,除非另有说明。
例如,HTML标准将定义,对于html
和HTML命名空间,使用HTMLHtmlElement
接口。[HTML]
createElement(localName, options)
方法步骤如下:
-
如果localName不匹配
名称
的生成,则抛出一个"InvalidCharacterError
"DOMException
。 -
将is设置为null。
-
如果this是一个HTML文档或this的内容类型为"
application/xhtml+xml
",则将namespace设置为HTML命名空间;否则为null。 -
返回给定this、localName、namespace、null、is和设置了同步自定义元素标志的创建元素的结果。
内部createElementNS
步骤,给定document、namespace、qualifiedName和options,如下:
-
让namespace、prefix和localName成为将namespace和qualifiedName传递给验证和提取的结果。
-
将is设置为null。
-
返回给定document、localName、namespace、prefix、is和设置了同步自定义元素标志的创建元素的结果。
createElementNS(namespace, qualifiedName, options)
方法步骤是返回给定this、namespace、qualifiedName和options运行内部createElementNS
步骤的结果。
createElement()
和createElementNS()
的options参数允许为字符串以保持Web兼容性。
createDocumentFragment()
方法步骤是返回一个新的DocumentFragment
节点,其节点文档为this。
createTextNode(data)
方法步骤是返回一个新的Text
节点,其数据为data,其节点文档为this。
不会检查data是否由符合Char
生成规则的字符组成。
createCDATASection(data)
方法步骤如下:
-
如果this是一个HTML文档,则抛出一个"
NotSupportedError
"DOMException
。 -
如果data包含字符串"
]]>
",则抛出一个"InvalidCharacterError
"DOMException
。 -
返回一个新的
CDATASection
节点,其数据设置为data,节点文档设置为this。
createComment(data)
方法步骤是返回一个新的Comment
节点,其数据为data,其节点文档为this。
不会检查data是否由符合Char
生成规则的字符组成,或是否包含两个相邻的连字符或以连字符结尾。
createProcessingInstruction(target, data)
方法步骤如下:
- 如果target不匹配
Name
的生成规则,则抛出一个"InvalidCharacterError
"DOMException
。 - 如果data包含字符串"
?>
",则抛出一个"InvalidCharacterError
"DOMException
。 - 返回一个新的
ProcessingInstruction
节点,其目标设置为target,数据设置为data,节点文档设置为this。
不会检查target是否包含"xml
"或":
",或data是否由符合Char
生成规则的字符组成。
- clone = document . importNode(node [, deep = false])
-
返回node的副本。如果deep为true,则副本也包括node的后代。
如果node是文档或影子根,则抛出一个"
NotSupportedError
"DOMException
。 - node = document .
adoptNode(node)
-
将node从另一个文档中移出并返回它。
如果node是一个文档,则抛出一个"
NotSupportedError
"DOMException
;或者,如果node是一个影子根,则抛出一个"HierarchyRequestError
"DOMException
。
importNode(node, deep)
方法步骤如下:
-
如果node是文档或影子根,则抛出一个"
NotSupportedError
"DOMException
。
规范可能会为所有或部分节点定义采用步骤。该算法将node和oldDocument作为输入,如采用算法中所示。
要将某个node采用到document中,执行以下步骤:
-
将oldDocument设为node的节点文档。
-
如果document不是oldDocument,则:
-
对于node的每个包括影子在内的包容性后代:
-
对于node的每个包括影子在内的包容性后代,如果它是自定义元素,则入列一个自定义元素回调反应,其中包括包括影子在内的包容性后代、回调名称"
adoptedCallback
",以及包含oldDocument和document的参数列表。 -
对于node的每个包括影子在内的包容性后代,按包括影子在内的树顺序运行采用步骤,输入参数为包括影子在内的包容性后代和oldDocument。
-
adoptNode(node)
方法步骤如下:
-
如果node是一个文档,则抛出一个"
NotSupportedError
"DOMException
。 -
如果node是一个影子根,则抛出一个"
HierarchyRequestError
"DOMException
。 -
如果node是一个DocumentFragment节点,其容器不为null,则返回。
-
返回node。
createAttribute(localName)
方法步骤如下:
-
如果localName不匹配
Name
在XML中的生成规则,则抛出一个"InvalidCharacterError
"DOMException
。
createAttributeNS(namespace, qualifiedName)
方法步骤如下:
-
将namespace、prefix和localName设为将namespace和qualifiedName传递给验证和提取的结果。
-
返回一个新的属性,其命名空间为namespace,命名空间前缀为prefix,本地名称为localName,节点文档为this。
createEvent(interface)
方法步骤如下:
-
将constructor设为null。
-
如果interface是与下表第一列中的任何字符串的ASCII不区分大小写匹配,则将constructor设置为同一行第二列中的接口:
字符串 接口 注释 " beforeunloadevent
"BeforeUnloadEvent
[HTML] " compositionevent
"CompositionEvent
[UIEVENTS] " customevent
"CustomEvent
" devicemotionevent
"DeviceMotionEvent
[DEVICE-ORIENTATION] " deviceorientationevent
"DeviceOrientationEvent
" dragevent
"DragEvent
[HTML] " event
"Event
" events
"" focusevent
"FocusEvent
[UIEVENTS] " hashchangeevent
"HashChangeEvent
[HTML] " htmlevents
"Event
" keyboardevent
"KeyboardEvent
[UIEVENTS] " messageevent
"MessageEvent
[HTML] " mouseevent
"MouseEvent
[UIEVENTS] " mouseevents
"" storageevent
"StorageEvent
[HTML] " svgevents
"Event
" textevent
"TextEvent
[UIEVENTS] " touchevent
"TouchEvent
[TOUCH-EVENTS] " uievent
"UIEvent
[UIEVENTS] " uievents
" -
如果constructor为null,则抛出一个"
NotSupportedError
"DOMException
。 -
如果constructor指示的接口未在相关全局对象中暴露给this,则抛出一个"
NotSupportedError
"DOMException
。通常用户代理在某些配置中禁用对触摸事件的支持,在这种情况下,此条款将适用于
TouchEvent
接口。 -
让event成为创建事件的结果,输入为constructor。
-
初始化event的
type
属性为空字符串。 -
初始化event的
isTrusted
属性为false。 -
取消设置event的初始化标志。
-
返回event。
Event构造器应该被使用。
createRange()
方法步骤是返回一个新的活动范围,其this为起始点(this,
0),并返回起始点和终点。
Range()
构造器可以被使用。
createNodeIterator(root, whatToShow, filter)
方法步骤如下:
-
让iterator成为一个新的
NodeIterator
对象。 -
将iterator的指针在参考之前设置为true。
-
将iterator的whatToShow设置为whatToShow。
-
将iterator的过滤器设置为filter。
-
返回iterator。
createTreeWalker(root, whatToShow, filter)
方法步骤如下:
-
让walker成为一个新的
TreeWalker
对象。 -
将walker的whatToShow设置为whatToShow。
-
将walker的过滤器 设置为filter。
- 返回walker。
4.5.1.接口 DOMImplementation
用户代理在创建文档时,必须创建一个DOMImplementation
对象,并将其与该文档关联。
[Exposed =Window ]interface { [
DOMImplementation NewObject ]DocumentType createDocumentType (DOMString ,
qualifiedName DOMString ,
publicId DOMString ); [
systemId NewObject ]XMLDocument createDocument (DOMString ?, [
namespace LegacyNullToEmptyString ]DOMString ,
qualifiedName optional DocumentType ?=
doctype null ); [NewObject ]Document createHTMLDocument (optional DOMString );
title boolean hasFeature (); // useless; always returns true };
doctype = document .
implementation
.createDocumentType(qualifiedName, publicId, systemId)
- 返回具有给定qualifiedName、publicId和systemId的doctype。如果qualifiedName与
Name
生产不匹配,将抛出“InvalidCharacterError
”DOMException
,如果它不匹配QName
生产,将抛出“NamespaceError
”DOMException
。 doc = document .
implementation
. createDocument(namespace, qualifiedName [, doctype = null])-
返回一个具有qualifiedName作为local
name,并且其namespace是namespace的XMLDocument,并且如果给出了doctype,它将作为其doctype。
当使用namespace和qualifiedName调用时,此方法抛出与
createElementNS()
方法相同的异常。 doc = document .
implementation
. createHTMLDocument([title])- 返回一个已经构建了基本树的document,包括一个
title
元素,除非省略了title参数。
createDocumentType(qualifiedName, publicId, systemId)
方法步骤如下:
-
验证qualifiedName。
-
返回一个新的doctype,其qualifiedName为其name,publicId为其public ID,systemId为其system ID,并且其node document设置为document。
不会检查publicId代码点是否匹配PubidChar
生产,或systemId是否同时包含'"
'和"'
"。
createDocument(namespace, qualifiedName, doctype)
方法步骤如下:
-
让document成为一个新的
XMLDocument
。 -
让element为null。
-
如果qualifiedName不是空字符串,则将element设置为运行内部createElementNS步骤的结果,给定document、namespace、qualifiedName和一个空字典。
-
如果doctype非空,则将doctype附加到document。
-
如果element非空,则将element附加到document。
-
document的内容类型由namespace决定:
- HTML namespace
application/xhtml+xml
- SVG namespace
image/svg+xml
- 任何其他命名空间
application/xml
-
返回document。
createHTMLDocument(title)
方法步骤如下:
-
让doc成为一个新的document,该文档是一个HTML document。
-
将doc的内容类型设置为“
text/html
”。 -
附加根据doc创建的元素的结果,
html
,并将HTML namespace附加到doc。 -
附加根据doc创建的元素的结果,
head
,并将HTML namespace附加到之前创建的html
元素。 -
如果给出了title:
-
附加根据doc创建的元素的结果,
body
,并将HTML namespace附加到之前创建的html
元素。 -
返回doc。
hasFeature()
方法步骤如下返回true。
hasFeature()
最初会报告用户代理是否声称支持给定的DOM功能,但经验表明,它远不如简单地检查所需对象、属性或方法是否存在来得可靠或细致。因此,它不再被使用,但为了确保旧页面不停止工作,它继续存在(并且仅返回true)。
4.6.
接口DocumentType
[Exposed =Window ]interface :
DocumentType Node {readonly attribute DOMString name ;readonly attribute DOMString publicId ;readonly attribute DOMString systemId ; };
DocumentType
节点通常被称为
文档类型定义(doctypes)。
文档类型定义(doctypes)具有 相关的名称(name)、公有标识符(public ID)和 系统标识符(system ID)。
创建文档类型定义(doctype)时,始终会提供其name。 除非在创建文档类型定义(doctype)时显式提供,否则其public ID和system ID将为空字符串。
publicId
获取器步骤是返回this的public ID。
systemId
获取器步骤是返回this的system ID。
4.7.
接口DocumentFragment
[Exposed =Window ]interface :
DocumentFragment Node {constructor (); };
DocumentFragment
节点有一个关联的
宿主(host)(为null或在不同元素的节点树中)。除非另有说明,否则为null。
对象A是对象B的包含宿主的包容性祖先(host-including inclusive ancestor), 如果A是B的包容性祖先, 或者如果B的根有一个非空的宿主, 并且A是B的包含宿主的包容性祖先 的根的 宿主。
DocumentFragment
节点的宿主概念
对于HTML的模板(template)
元素和影子根(shadow
roots)非常有用,并且会影响预插入(pre-insert)和替换(replace)算法。
tree = new
DocumentFragment()
- 返回一个新的
DocumentFragment
节点。
new DocumentFragment()
构造函数步骤
是将this的节点文档设置为当前全局对象的关联Document
。
4.8.
接口ShadowRoot
[Exposed =Window ]interface :
ShadowRoot DocumentFragment {readonly attribute ShadowRootMode mode ;readonly attribute boolean delegatesFocus ;readonly attribute SlotAssignmentMode slotAssignment ;readonly attribute boolean clonable ;readonly attribute boolean serializable ;readonly attribute Element host ;attribute EventHandler onslotchange ; };enum {
ShadowRootMode ,
"open" };
"closed" enum {
SlotAssignmentMode ,
"manual" };
"named"
ShadowRoot
节点通常被称为
影子根(shadow roots)。
影子根(Shadow
roots)有一个关联的模式(mode)(“open
”或“closed
”)。
影子根(Shadow roots)有一个关联的委派焦点(delegates focus)。它最初设置为false。
影子根(Shadow roots)有一个关联的可用于元素内部(available to element internals)。它最初设置为false。
影子根(Shadow roots)有一个关联的声明性(declarative)(一个布尔值)。它最初设置为false。
影子根(Shadow
roots)的关联宿主(host)
从不为null。
影子根(Shadow
roots)有一个关联的槽分配(slot
assignment)(“manual
”或“named
”)。
影子根(Shadow roots)有一个关联的可克隆性(clonable)(一个布尔值)。它最初设置为false。
影子根(Shadow roots)有一个关联的可序列化性(serializable)(一个布尔值)。它最初设置为false。
给定一个event,影子根(shadow root)的获取父级(get the
parent)算法返回null,如果event的组合标志(composed
flag)未设置并且影子根
是event的路径的第一个结构的调用目标的根
;否则返回影子根
的宿主
。
delegatesFocus
获取器步骤是返回this的委派焦点(delegates focus)
。
slotAssignment
获取器步骤是返回this的槽分配
。
serializable
获取器步骤是返回this的可序列化性
。
onslotchange
属性是一个事件处理程序IDL属性,用于onslotchange
事件处理程序,其事件处理程序事件类型是slotchange
。
在影子包括树顺序(shadow-including tree order)中,是影子包括的先序,深度优先遍历(shadow-including preorder, depth-first traversal)节点树。影子包括的先序,深度优先遍历(Shadow-including preorder, depth-first traversal)是tree的先序,深度优先遍历,在tree中遇到的每个影子宿主(shadow host),影子包括的先序,深度优先遍历该元素的影子根的节点树,就在它被遇到之后。
shadow-including root 是对象的 root 的 host 的 shadow-including root,如果对象的 root 是一个 shadow root;否则为它的 root。
对象A是对象B的影子包括的后代(shadow-including
descendant),如果A是B的后代,或者A的根是影子根,并且A的根
的宿主
是影子包括的包容性后代(shadow-including inclusive descendant)
B。
影子包括的包容性后代(shadow-including inclusive descendant)是一个对象或其影子包括的后代之一。
对象A是对象B的影子包括的祖先(shadow-including
ancestor),当且仅当B是A的影子包括的后代
。
影子包括的包容性祖先(shadow-including inclusive ancestor)是一个对象或其影子包括的祖先之一。
节点A从节点B
中是闭合影子隐藏的(closed-shadow-hidden),如果以下所有条件都为真:
为了重新定位(retarget)对象A相对于对象B,重复这些步骤直到返回一个对象:
重新定位(retargeting)
算法由事件调度
以及其他规范(如Fullscreen
)使用。[FULLSCREEN]
4.9.接口Element
[Exposed =Window ]interface :
Element Node {readonly attribute DOMString ?namespaceURI ;readonly attribute DOMString ?prefix ;readonly attribute DOMString localName ;readonly attribute DOMString tagName ; [CEReactions ]attribute DOMString id ; [CEReactions ]attribute DOMString className ; [SameObject ,PutForwards =value ]readonly attribute DOMTokenList classList ; [CEReactions ,Unscopable ]attribute DOMString slot ;boolean hasAttributes (); [SameObject ]readonly attribute NamedNodeMap attributes ;sequence <DOMString >getAttributeNames ();DOMString ?getAttribute (DOMString );
qualifiedName DOMString ?getAttributeNS (DOMString ?,
namespace DOMString ); [
localName CEReactions ]undefined setAttribute (DOMString ,
qualifiedName DOMString ); [
value CEReactions ]undefined setAttributeNS (DOMString ?,
namespace DOMString ,
qualifiedName DOMString ); [
value CEReactions ]undefined removeAttribute (DOMString ); [
qualifiedName CEReactions ]undefined removeAttributeNS (DOMString ?,
namespace DOMString ); [
localName CEReactions ]boolean toggleAttribute (DOMString ,
qualifiedName optional boolean );
force boolean hasAttribute (DOMString );
qualifiedName boolean hasAttributeNS (DOMString ?,
namespace DOMString );
localName Attr ?getAttributeNode (DOMString );
qualifiedName Attr ?getAttributeNodeNS (DOMString ?,
namespace DOMString ); [
localName CEReactions ]Attr ?setAttributeNode (Attr ); [
attr CEReactions ]Attr ?setAttributeNodeNS (Attr ); [
attr CEReactions ]Attr removeAttributeNode (Attr );
attr ShadowRoot attachShadow (ShadowRootInit );
init readonly attribute ShadowRoot ?shadowRoot ;Element ?closest (DOMString );
selectors boolean matches (DOMString );
selectors boolean webkitMatchesSelector (DOMString ); // legacy alias of .matches
selectors HTMLCollection getElementsByTagName (DOMString );
qualifiedName HTMLCollection getElementsByTagNameNS (DOMString ?,
namespace DOMString );
localName HTMLCollection getElementsByClassName (DOMString ); [
classNames CEReactions ]Element ?insertAdjacentElement (DOMString ,
where Element ); // legacy
element undefined insertAdjacentText (DOMString ,
where DOMString ); // legacy };
data dictionary {
ShadowRootInit required ShadowRootMode ;
mode boolean =
delegatesFocus false ;SlotAssignmentMode = "named";
slotAssignment boolean =
clonable false ;boolean =
serializable false ; };
元素(Elements)有一个关联的命名空间(namespace)、命名空间前缀(namespace
prefix)、本地名称(local name)、自定义元素状态(custom element
state)、自定义元素定义(custom element
definition)、is
值。当创建元素时,所有这些值都会被初始化。
元素的自定义元素状态是“undefined
”、“failed
”、“uncustomized
”、“precustomized
”或“custom
”之一。元素的自定义元素状态为“uncustomized
”或“custom
”时,被称为已定义(defined)。元素的自定义元素状态为“custom
”时,被称为自定义(custom)。
元素是否被定义用于确定:defined
伪类的行为。元素是否被自定义用于确定变动算法(mutation algorithms)
的行为。“failed
”和“precustomized
”状态用于确保如果自定义元素构造函数(custom element
constructor)第一次执行失败,它不会在元素升级(upgrade)
时再次执行。
以下代码展示了处于这四种状态中的元素:
<!DOCTYPE html>
< script >
window. customElements. define( "sw-rey" , class extends HTMLElement {})
window. customElements. define( "sw-finn" , class extends HTMLElement {}, { extends : "p" })
window. customElements. define( "sw-kylo" , class extends HTMLElement {
constructor () {
// super() intentionally omitted for this example
}
})
</ script >
<!-- "undefined" (not defined, not custom) -->
< sw-han ></ sw-han >
< p is = "sw-luke" ></ p >
< p is = "asdf" ></ p >
<!-- "failed" (not defined, not custom) -->
< sw-kylo ></ sw-kylo >
<!-- "uncustomized" (defined, not custom) -->
< p ></ p >
< asdf ></ asdf >
<!-- "custom" (defined, custom) -->
< sw-rey ></ sw-rey >
< p is = "sw-finn" ></ p >
元素 也有一个关联的 shadow root(为 null 或一个 shadow root)。除非另有说明,否则它为 null。如果一个 元素 的 shadow root 不为 null,那么该元素就是一个 shadow host。
元素的限定名称(qualified
name)是其本地名称
,如果其命名空间前缀
为null;否则为其命名空间前缀
,后跟“:
”,再后跟其本地名称
。
元素的HTML大写限定名称(HTML-uppercased qualified name)的返回值通过以下步骤获得:
用户代理可以通过将限定名称(qualified name)和HTML大写限定名称(HTML-uppercased qualified name)存储在内部槽中来进行优化。
为了创建一个元素(create an element),给定document、localName、namespace和可选的prefix、is、synchronous custom elements flag,执行以下步骤:
-
如果未给定prefix,则将prefix设为null。
-
如果未给定is,则将is设为null。
-
将result设为null。
-
将definition设为通过查找自定义元素定义给定document、namespace、localName和is的结果。
-
如果definition非null,并且definition的名称不等于其本地名称(即definition表示一个定制内置元素(customized built-in element)),则:
-
否则,如果definition非null,则:
-
如果设置了synchronous custom elements flag,则在捕获任何异常的同时执行以下步骤:
-
设C为definition的
构造函数
。 -
将result设为
构造
C的结果,没有参数。 -
IDL 强制规定result是一个
HTMLElement
对象,所有这些对象都使用HTML命名空间。 -
如果result的
属性列表
不为空,则抛出
NotSupportedError
的DOMException
。 -
如果result有
子节点
,则抛出
NotSupportedError
的DOMException
。 -
如果result的
父节点
非空,则抛出
NotSupportedError
的DOMException
。 -
如果result的
节点文档
不是document,则抛出
NotSupportedError
的DOMException
。 -
如果result的
本地名称
不等于localName,则抛出
NotSupportedError
的DOMException
。 -
将result的
命名空间前缀
设置为prefix。 -
将result的
设置为null。is
值
如果这些步骤中的任何一步抛出异常,则:
-
-
否则:
-
-
否则:
-
返回result。
元素也有一个属性列表,它是通过NamedNodeMap
公开的一个列表。除非在创建元素时明确指定,否则其属性列表为空。
本规范和其他规范可能为元素定义属性更改步骤。该算法传递element、localName、oldValue、value和namespace。
要处理属性更改,对于具有element、oldValue和newValue的属性attribute,执行以下步骤:
-
排队一个突变记录,内容为“
attributes
”,适用于element,包含attribute的本地名称、attribute的命名空间、oldValue、“« »”和null。 -
如果element是自定义的,则排队一个自定义元素回调反应,适用于element,回调名称为“
attributeChangedCallback
”,并包含一个参数列表,其中包含attribute的本地名称、oldValue、newValue和attribute的命名空间。 -
运行属性更改步骤,给定element、attribute的本地名称、oldValue、newValue和attribute的命名空间。
要更改属性attribute的value,执行以下步骤:
要附加属性attribute到元素element,执行以下步骤:
要移除属性attribute,执行以下步骤:
要替换属性oldAttr为属性newAttr,执行以下步骤:
-
将oldAttr的元素设为null。
要按名称获取属性,给定一个字符串qualifiedName和一个元素element:
要按命名空间和本地名称获取属性,给定null或一个字符串namespace、一个字符串localName和一个元素element:
要获取属性值,给定一个元素element、一个字符串localName,以及一个可选的null或字符串namespace(默认值为null):
-
让attr是按命名空间和本地名称获取属性的结果,给定namespace、localName和element。
-
如果attr为null,则返回空字符串。
-
返回attr的值。
-
如果attr的元素既不为null也不为element,则抛出一个“
InUseAttributeError
”DOMException
。 -
如果oldAttr为attr,则返回attr。
-
如果oldAttr不为null,则用attr替换oldAttr。
-
否则,将attr附加到element。
-
返回oldAttr。
要设置属性值,给定一个元素element、一个字符串localName、一个字符串value,一个可选的null或字符串prefix(默认值为null),以及一个可选的null或字符串namespace(默认值为null):
要按名称移除属性,给定一个字符串qualifiedName和一个元素element:
-
让attr是按名称获取属性的结果,给定qualifiedName和element。
-
如果attr不为null,则移除attr。
-
返回attr。
要按命名空间和本地名称移除属性,给定null或一个字符串namespace、一个字符串localName和一个元素element:
-
让attr是按命名空间和本地名称获取属性的结果,给定namespace、localName和element。
-
如果attr不为null,则移除attr。
-
返回attr。
一个 元素 可以有一个关联的 唯一标识符(ID)
历史上,元素 可以通过使用 HTML 的 id
属性 和
DTD 拥有多个标识符。该规范将 ID
作为 DOM 的概念,并允许每个 元素
只有一个由 id
属性 给出的标识符。
-
如果 localName 是
id
,namespace 为 null,且 value 为 null 或为空字符串,则取消 element 的 ID。 -
否则,如果 localName 是
id
,namespace 为 null,则将 element 的 ID 设置为 value。
虽然本规范定义了任何 元素 上 class
、id
和
slot
属性
的要求,但并未说明使用它们是否符合规范。
一个 节点 类型为 Element
的 父节点
被称为它的 父元素。如果 节点 的 父节点
是不同类型,它的 父元素 为 null。
- namespace = element .
namespaceURI
- 返回 命名空间。
- prefix = element .
prefix
- 返回 命名空间前缀。
- localName = element .
localName
- 返回 本地名称。
- qualifiedName = element .
tagName
- 返回 HTML大写合格名称。
namespaceURI
的 getter 步骤是返回
this 的
命名空间。
prefix
的 getter 步骤是返回 this 的 命名空间前缀。
localName
的 getter 步骤是返回 this 的 本地名称。
tagName
的 getter 步骤是返回 this 的 HTML大写合格名称。
element . id [ = value ]
-
返回 element 的
id
内容属性的值。可以设置以更改它。 element . className [ = value ]
-
返回 element 的
class
内容属性的值。可以设置以更改它。 element . classList
-
允许通过
DOMTokenList
对象以一组以空格分隔的标记来操作 element 的class
内容属性。 element . slot [ = value ]
-
返回 element 的
slot
内容属性的值。可以设置以更改它。
定义为 反映字符串 name 的 IDL 属性,必须有这些 getter 和 setter 步骤:
id
属性必须 反映 "id
"。
className
属性必须 反映
"class
"。
classList
的 getter 步骤是返回一个
DOMTokenList
对象,其关联的 元素 是 this,且其关联的
属性 的
本地名称 是 class
。这个特定 DOMTokenList
对象的 标记集 也被称为
元素 的 类。
slot
属性必须 反映 "slot
"。
id
、class
和 slot
实际上是超级全局属性,因为它们可以出现在任何元素上,无论该元素的命名空间如何。
element . hasAttributes()
-
如果 element 有属性则返回 true;否则返回 false。
element . getAttributeNames()
-
返回 element 的所有 限定名称。可能包含重复项。
element . getAttribute(qualifiedName)
-
返回 element 的第一个 属性,其 限定名称 为 qualifiedName,如果没有这样的 属性,则返回 null。
element . getAttributeNS(namespace, localName)
-
返回 element 的 属性,其 命名空间 是 namespace,且 本地名称 是 localName,如果没有这样的 属性,则返回 null。
element . setAttribute(qualifiedName, value)
element . setAttributeNS(namespace, localName, value)
-
设置 element 的 属性 的 值,其 命名空间 是 namespace,且 本地名称 是 localName,并将其设置为 value。
element . removeAttribute(qualifiedName)
element . removeAttributeNS(namespace, localName)
element . toggleAttribute(qualifiedName [, force])
-
如果没有给定 force,则“切换” qualifiedName,如果存在则移除它,如果不存在则添加它。如果 force 为 true,则添加 qualifiedName。如果 force 为 false,则移除 qualifiedName。
如果 qualifiedName 现在存在则返回 true;否则返回 false。
element . hasAttribute(qualifiedName)
-
如果 element 具有 属性,其 限定名称 为 qualifiedName,则返回 true;否则返回 false。
element . hasAttributeNS(namespace, localName)
-
如果 element 具有 属性,其 命名空间 是 namespace,且 本地名称 是 localName,则返回 true;否则返回 false。
hasAttributes()
方法的步骤是,如果 this 的
属性列表
为空,则返回
false;否则返回 true。
attributes
的 getter 步骤是返回关联的
NamedNodeMap
。
getAttributeNames()
方法的步骤是按顺序返回 限定名称,如果存在,属性 在 this 的 属性列表
中;否则返回一个新的 列表。
这些不能保证是唯一的。
getAttribute(qualifiedName)
方法的步骤是:
getAttributeNS(namespace, localName)
方法的步骤是:
setAttribute(qualifiedName, value)
方法的步骤是:
-
如果 qualifiedName 与 XML 中的
Name
生产不匹配,则 抛出 一个 "InvalidCharacterError
"DOMException
。 -
如果 this 在 HTML 命名空间 中,并且其 节点文档 是 HTML 文档,则将 qualifiedName 设置为 qualifiedName 的 ASCII 小写字母。
-
让 attribute 成为 this 的 属性列表 中第一个 属性,其 限定名称 为 qualifiedName,否则为 null。
-
如果 attribute 为 null,创建一个 属性,其 本地名称 为 qualifiedName,值 为 value,节点文档 为 this 的 节点文档,然后 将此属性添加到 this,然后返回。
-
更改 attribute 为 value。
setAttributeNS(namespace, qualifiedName, value)
方法的步骤是:
-
将 namespace、prefix 和 localName 作为传递 namespace 和 qualifiedName 的结果传递给 验证和提取。
-
使用 localName、value 以及 prefix 和 namespace 设置属性值。
removeAttribute(qualifiedName)
方法的步骤是给定 qualifiedName 和 this 移除属性,然后返回 undefined。
removeAttributeNS(namespace, localName)
方法的步骤是给定 namespace、localName 和 this 移除属性,然后返回 undefined。
hasAttribute(qualifiedName)
方法的步骤是:
-
如果 this 在 HTML 命名空间 中,并且其 节点文档 是 HTML 文档,则将 qualifiedName 设置为 qualifiedName 的 ASCII 小写字母。
toggleAttribute(qualifiedName, force)
方法的步骤是:
-
如果 qualifiedName 与 XML 中的
Name
生产不匹配,则 抛出 一个 "InvalidCharacterError
"DOMException
。 -
如果 this 在 HTML 命名空间 中,并且其 节点文档 是 HTML 文档,则将 qualifiedName 设置为 qualifiedName 的 ASCII 小写字母。
-
让 attribute 成为 this 的 属性列表 中第一个 属性,其 限定名称 为 qualifiedName,否则为 null。
-
如果 attribute 为 null,则:
-
否则,如果未给定 force 或为 false,给定 qualifiedName 和 this 移除属性,然后返回 false。
-
返回 true。
hasAttributeNS(namespace, localName)
方法的步骤是:
-
如果 namespace 为空字符串,则将其设置为 null。
- 如果 this 具有一个 属性,其 命名空间 是 namespace,且 本地名称 是 localName,则返回 true;否则返回 false。
getAttributeNode(qualifiedName)
方法的步骤是返回给定 qualifiedName 和 this 的 获取属性 的结果。
getAttributeNodeNS(namespace, localName)
方法的步骤是返回给定 namespace、localName 和 this 的 获取属性 的结果。
setAttributeNode(attr)
和
setAttributeNodeNS(attr)
方法的步骤是返回给定 attr 和 this 的 设置属性 的结果。
removeAttributeNode(attr)
方法的步骤如下:
-
如果 this 的 属性列表 不 包含 attr,则 抛出 一个 "
NotFoundError
"DOMException
。 -
移除 attr。
-
返回 attr。
var shadow = element .
attachShadow(init)
-
为 element 创建一个 shadow root 并返回它。
var shadow = element .
shadowRoot
-
返回 element 的 shadow root,如果有,并且如果 shadow root 的 mode 是 "
open
",否则返回 null。
有效的 shadow 宿主名称 是:
- 一个 有效的自定义元素名称
- "
article
", "aside
", "blockquote
", "body
", "div
", "footer
", "h1
", "h2
", "h3
", "h4
", "h5
", "h6
", "header
", "main
", "nav
", "p
", "section
", 或 "span
"
attachShadow(init)
方法的步骤是:
-
运行 附加一个 shadow root,使用 this,init["
mode
"], init["clonable
"], init["serializable
"], init["delegatesFocus
"], 和 init["slotAssignment
"]。 -
返回 this 的 shadow root。
要 附加一个 shadow root,给定一个 元素 element,一个字符串 mode,一个布尔值 clonable,一个布尔值 serializable,一个布尔值 delegatesFocus,和一个字符串 slotAssignment:
-
如果 element 的 命名空间 不是 HTML 命名空间,则 抛出一个 "
NotSupportedError
"DOMException
。 -
如果 element 的 本地名称 不是一个 有效的 shadow 宿主名称,则 抛出一个 "
NotSupportedError
"DOMException
。 -
如果 element 的 本地名称 是一个 有效的自定义元素名称,或者 element 的
is
值 不为空,则:-
让 definition 成为给定 element 的 节点文档、其 命名空间、其 本地名称 和其
is
值 的 查找自定义元素定义 的结果。 -
如果 definition 不为空并且 definition 的 禁用 shadow 为真,则 抛出一个 "
NotSupportedError
"DOMException
。
-
-
如果 element 是一个 shadow 宿主,则:
-
让 currentShadowRoot 成为 element 的 shadow root。
-
如果以下任意一项为真:
则 抛出一个 "
NotSupportedError
"DOMException
。 -
否则:
-
-
让 shadow 成为一个新的 shadow root,其 节点文档 是 element 的 节点文档,宿主 是 element,模式 是 mode。
-
将 shadow 的 delegates focus 设置为 delegatesFocus。
-
如果 element 的 自定义元素状态 是 "
precustomized
" 或 "custom
",则将 shadow 的 可用于元素内部 设置为真。 -
将 shadow 的 slot assignment 设置为 slotAssignment。
-
将 shadow 的 声明式 设置为假。
-
将 shadow 的 clonable 设置为 clonable。
-
将 shadow 的 serializable 设置为 serializable。
-
将 element 的 shadow root 设置为 shadow。
shadowRoot
getter 方法的步骤是:
-
让 shadow 成为 this 的 shadow root。
-
如果 shadow 为 null 或其 模式 为 "
closed
",则返回 null。 -
返回 shadow。
element .
closest(selectors)
- 返回第一个(从 element 开始)匹配 selectors 的 包含祖先,否则返回 null。
element .
matches(selectors)
- 如果匹配 selectors 时,element 的 根 返回 element,则返回 true;否则返回 false。
closest(selectors)
方法的步骤是:
-
让 s 成为从 selectors 解析选择器 的结果。[SELECTORS4]
-
如果 s 解析失败,则 抛出一个 "
SyntaxError
"DOMException
。 -
对于 elements 中的每个 element,如果使用 s、element 和 scoping root 匹配选择器成功,则返回 element。[SELECTORS4]
-
返回 null。
matches(selectors)
和 webkitMatchesSelector(selectors)
方法的步骤是:
-
让 s 成为从 selectors 解析选择器 的结果。[SELECTORS4]
-
如果 s 解析失败,则 抛出一个 "
SyntaxError
"DOMException
。 -
如果使用 s、this 和 scoping root 匹配选择器的结果为成功,则返回 true;否则返回 false。[SELECTORS4]
getElementsByTagName(qualifiedName)
方法的步骤是返回 具有限定名称 qualifiedName 的元素列表,用于
this。
getElementsByTagNameNS(namespace, localName)
方法的步骤是返回 具有命名空间 namespace 和本地名称
localName 的元素列表,用于 this。
getElementsByClassName(classNames)
方法的步骤是返回 具有类名 classNames 的元素列表,用于 this。
要插入相邻元素,给定一个 元素 element、字符串 where 和一个 节点 node,执行与 where 的第一个 ASCII 不区分大小写 匹配相关的步骤:
- "
beforebegin
" -
如果 element 的 父节点 为 null,则返回 null。
- "
afterbegin
" - "
beforeend
" -
返回 预插入 node 到 element 之前 null 的结果。
- "
afterend
" -
如果 element 的 父节点 为 null,则返回 null。
- 否则
insertAdjacentElement(where, element)
方法的步骤是返回运行 插入相邻元素
的结果,给定 this、where 和 element。
insertAdjacentText(where, data)
方法的步骤是:
此方法不返回任何内容,因为它在我们有机会设计它之前就已存在。
4.9.1.
接口 NamedNodeMap
[Exposed =Window ,LegacyUnenumerableNamedProperties ]interface {
NamedNodeMap readonly attribute unsigned long length ;getter Attr ?item (unsigned long );
index getter Attr ?getNamedItem (DOMString );
qualifiedName Attr ?getNamedItemNS (DOMString ?,
namespace DOMString ); [
localName CEReactions ]Attr ?setNamedItem (Attr ); [
attr CEReactions ]Attr ?setNamedItemNS (Attr ); [
attr CEReactions ]Attr removeNamedItem (DOMString ); [
qualifiedName CEReactions ]Attr removeNamedItemNS (DOMString ?,
namespace DOMString ); };
localName
一个 NamedNodeMap
有一个关联的 元素(一个 元素)。
一个 NamedNodeMap
对象的 属性列表 是它的 元素的
属性列表。
一个 NamedNodeMap
对象的 支持的属性索引 是
零到它的 属性列表 的 大小 减一范围内的数字,
除非
属性列表 为空,
在这种情况下没有 支持的属性索引。
item(index)
方法
步骤为:
一个 NamedNodeMap
对象的 支持的属性名称 是运行
这些步骤返回的值:
-
让 names 成为此
NamedNodeMap
对象的 属性列表 中 限定名称 的列表, 去掉重复的,在 顺序中。 -
如果这个
NamedNodeMap
对象的 元素 在 HTML 命名空间 中,并且它的 节点文档 是一个 HTML 文档,则 对于每个 name 在 names 中:-
将 name 转换为 ASCII 小写,结果赋值给 lowercaseName。
-
如果 lowercaseName 不等于 name,则从 names 中移除 name。
-
-
返回 names。
getNamedItem(qualifiedName)
方法
步骤是返回给定 qualifiedName 和 元素 的
获取属性 的结果。
getNamedItemNS(namespace, localName)
方法步骤是返回给定 namespace、localName 和 元素 的
获取属性 的结果。
setNamedItem(attr)
和
setNamedItemNS(attr)
方法步骤是返回给定 attr 和 元素 的
设置属性 的结果。
removeNamedItem(qualifiedName)
方法步骤是:
-
如果 attr 为 null,则 抛出 一个 "
NotFoundError
"DOMException
。 -
返回 attr。
removeNamedItemNS(namespace, localName)
方法步骤是:
-
如果 attr 为 null,则 抛出 一个 "
NotFoundError
"DOMException
。 -
返回 attr。
4.9.2.
接口 Attr
[Exposed =Window ]interface :
Attr Node {readonly attribute DOMString ?namespaceURI ;readonly attribute DOMString ?prefix ;readonly attribute DOMString localName ;readonly attribute DOMString name ; [CEReactions ]attribute DOMString value ;readonly attribute Element ?ownerElement ;readonly attribute boolean specified ; // useless; always returns true };
Attr
节点简单地被称为属性。为了避免与IDL属性混淆,它们有时被称为内容属性。
属性具有一个命名空间(空或非空字符串)、一个命名空间前缀(空或非空字符串)、一个本地名称(一个非空字符串)、一个值(字符串),以及一个元素(空或元素)。
如果现在设计它们,它们可能只会有一个名称和一个值。☹
一个属性的限定名称是它的本地名称,如果它的命名空间前缀为空,否则它的限定名称是它的命名空间前缀,后跟":
",后跟它的本地名称。
用户代理可以将其作为一个内部槽进行优化。
当创建一个属性时,其本地名称会被赋予。除非在创建属性时明确给出,否则其命名空间、命名空间前缀和元素会被设置为空,而其值会被设置为空字符串。
一个A
属性是一个属性,其本地名称是A
,并且其命名空间和命名空间前缀为空。
namespaceURI
的getter步骤是返回this的命名空间。
prefix
的getter步骤是返回this的命名空间前缀。
localName
的getter步骤是返回this的本地名称。
要设置现有属性值,给定一个属性 attribute 和一个字符串 value,请运行以下步骤:
value
的setter步骤是使用设置现有属性值,传递this和给定的值。
ownerElement
的getter步骤是返回this的元素。
specified
的getter步骤是返回 true。
4.10.接口 CharacterData
[Exposed =Window ]interface :
CharacterData Node {attribute [LegacyNullToEmptyString ]DOMString data ;readonly attribute unsigned long length ;DOMString substringData (unsigned long ,
offset unsigned long );
count undefined appendData (DOMString );
data undefined insertData (unsigned long ,
offset DOMString );
data undefined deleteData (unsigned long ,
offset unsigned long );
count undefined replaceData (unsigned long ,
offset unsigned long ,
count DOMString ); };
data
CharacterData
是一个抽象接口。你无法直接实例化它。它被用于 Text
,ProcessingInstruction
和 Comment
节点。
继承自 CharacterData
接口的每个 节点
都有一个关联的可变字符串,称为 data。
要用偏移 offset、计数 count 和数据 data 来 替换 节点 node 的数据,请执行以下步骤:
- 令 length 为 node 的 长度。
- 如果 offset 大于 length,则 抛出 一个
"
IndexSizeError
"DOMException
。 - 如果 offset 加上 count 大于 length,则将 count 设置为 length 减去 offset。
-
排队一个 "
characterData
" 的突变记录,记录为 node,其中包括 null,null,node 的 data,« »,« »,null 和 null。 - 在 node 的 data 中的 offset 之后插入 data 代码单元。
- 令 delete offset 为 offset 加上 data 的 长度。
- 从 delete offset 代码单元 开始,从 node 的 data 中删除 count 个 代码单元。
-
对于每个 实时范围,其 起始节点 为 node 且 起始偏移量 大于 offset 但小于或等于 offset 加 count,将其 起始偏移量 设置为 offset。
-
对于每个 实时范围,其 结束节点 为 node 且 结束偏移量 大于 offset 但小于或等于 offset 加 count,将其 结束偏移量 设置为 offset。
-
对于每个 实时范围,其 起始节点 为 node 且 起始偏移量 大于 offset 加 count,将其 起始偏移量 增加 data 的 长度 并减少 count。
-
对于每个 实时范围,其 结束节点 为 node 且 结束偏移量 大于 offset 加 count,将其 结束偏移量 增加 data 的 长度 并减少 count。
要通过节点 node、偏移量 offset 和计数 count 获取子字符串,请执行以下步骤:
- 令 length 为 node 的 长度。
- 如果 offset 大于 length,则 抛出 一个
"
IndexSizeError
"DOMException
。 - 如果 offset 加上 count 大于 length,则返回一个字符串,其值为从 offset 开始的 th 个 代码单元 到 node 的 data 末尾的代码单元,然后返回。
- 返回一个字符串,其值为从 offset th 个 代码单元 到 offset + count th 个 代码单元 的值,在 node 的 data 中。
data
getter 步骤是返回 this 的 data。其 setter
必须通过节点 this、偏移量
0、计数 this 的 长度 和数据
new value 替换数据。
length
getter 步骤是返回 this 的 长度。
substringData(offset, count)
方法步骤是返回通过节点 this、偏移量 offset 和计数 count 运行 子字符串数据
的结果。
appendData(data)
方法步骤是通过节点 this、偏移量 this 的 长度、计数 0
和数据 data 来 替换数据。
insertData(offset, data)
方法步骤是通过节点 this、偏移量 offset、计数 0 和数据 data 来 替换数据。
deleteData(offset, count)
方法步骤是通过节点 this、偏移量 offset、计数 count 和数据空字符串来 替换数据。
replaceData(offset, count, data)
方法步骤是通过节点 this、偏移量 offset、计数 count 和数据
data 来 替换数据。
4.11.
接口 Text
[Exposed =Window ]interface :
Text CharacterData {constructor (optional DOMString = ""); [
data NewObject ]Text splitText (unsigned long );
offset readonly attribute DOMString wholeText ; };
text = new Text([data = ""])
- 返回一个新的
Text
节点,其 数据为 data。 text .
splitText(offset)
- 在给定的 offset 处拆分
数据,
并将剩余部分作为
Text
节点返回。 text .
wholeText
- 返回所有直接的
Text
节点 兄弟节点的组合 数据。
一个 排他
Text
节点
是一个
Text
节点,不是
CDATASection
节点。
节点node的连续的
Text
节点
包括node、node的
前一个兄弟
Text
节点(如有),以及它的
连续的
Text
节点,还有node的
下一个
兄弟
Text
节点(如有),以及它的
连续的
Text
节点,避免任何重复。
节点node的连续的
排他 Text
节点
包括node、node的
前一个兄弟
排他
Text
节点(如有),以及它的
连续的
排他 Text
节点,还有node的
下一个
兄弟
排他
Text
节点(如有),以及它的
连续的
排他 Text
节点,避免任何重复。
节点node的子文本
内容
是所有node的Text
节点
子节点的
串联
数据,
按照树顺序排列。
节点node的后代
文本内容是所有node的Text
节点
后代的
串联
数据,
按照树顺序排列。
构造函数new Text(data)
的步骤为
将this的数据设置为data
并将this的节点文档设置为
当前全局对象的关联的 Document
。
- 令length为node的长度。
- 如果offset大于length,则抛出
一个 "
IndexSizeError
"DOMException
。 - 令count为length减去offset。
- 令new data为截取 数据的结果,节点为node,偏移量为 offset,计数为count。
- 令new node为一个新的
Text
节点,其 节点文档与node相同。 将new node的数据设置为new data。 - 令parent为node的父节点。
-
如果parent不为null,则:
- 替换 数据节点为node,偏移量为offset,计数为count,数据为空。
- 返回new node。
方法splitText(offset)
的步骤是
拆分
此偏移量为offset。
wholeText
的 getter 步骤是返回 串联
数据的 连续的
Text
节点,按 树顺序 进行。
4.12.
接口 CDATASection
[Exposed =Window ]interface :
CDATASection Text { };
4.13.
接口 ProcessingInstruction
[Exposed =Window ]interface :
ProcessingInstruction CharacterData {readonly attribute DOMString target ; };
4.14.
接口 注释
[Exposed =Window ]interface :
Comment CharacterData {constructor (optional DOMString = ""); };
data
comment = new Comment([data = ""])
- 返回一个新的
注释
节点,其 数据 是 data。
new Comment(data)
构造步骤
是将 此 的
数据 设置为
data,
并将 此 的
节点文档
设置为 当前全局对象 的 关联的 文档
。
5. Ranges
5.1. Introduction to "DOM Ranges"
StaticRange
和 Range
对象(ranges)表示 节点树 中的一段内容。每个 range 有一个 起点 和一个 终点,它们是 边界点。边界点 是由 节点 和 偏移量 组成的 元组。换句话说,range 表示在两个 边界点 之间的 节点树 中的一段内容。
Ranges 经常在编辑中用于选择和复制内容。
-
Element
:p
在上面的 节点树 中,range 可以用来表示 “syndata is
awes” 这一序列。假设将 p 赋值给 p
元素,并将 em 赋值给 em
元素,这可以按如下方式进行:
var range = new Range(),
firstText = p. childNodes[ 1 ],
secondText = em. firstChild
range. setStart( firstText, 9 ) // do not forget the leading space
range. setEnd( secondText, 4 )
// range now stringifies to the aforementioned quote
属性,如上面 节点树 中的 src
和 alt
,无法通过 range 表示。Ranges 仅对 节点 有用。
Range
对象与 StaticRange
对象不同,会受到 节点树
变更的影响。因此它们也被称为 实时范围。这种变更不会使它们无效,并会尝试确保它仍然表示相同的内容。必要时,实时范围 本身可能会在 节点树 的变更中被修改,例如当它表示的部分内容被修改时。
有关详细信息,请参阅 插入 和 移除 算法,normalize()
方法,以及 替换数据 和 分割 算法。
响应 节点树 变更而更新 实时范围 可能代价高昂。对于每次
节点树 变更,所有受影响的 Range
对象都需要更新。即使应用程序对某些
实时范围
不感兴趣,它仍然需要在发生变更时支付保持它们最新状态的代价。
StaticRange
对象是一个轻量级的 范围,当 节点树
变更时,它不会更新。因此,它不受与 实时范围 相同的维护成本的影响。
5.2. Boundary points
边界点 是一个由 元组 组成的结构,包含一个 节点(节点)和一个 偏移量(一个非负整数)。
一个正确的 边界点 的 偏移量 应在 0 到该 边界点 的 节点 的 长度 之间(包括 0 和长度)。
位置 是指 边界点 (nodeA, offsetA) 相对于 边界点 (nodeB, offsetB) 的 前、等于 或 后,以下步骤将返回结果:
-
断言:nodeA 和 nodeB 具有相同的 根。
- 如果 nodeA 是 nodeB,则如果 offsetA 等于 offsetB,返回 等于;如果 offsetA 小于 offsetB,返回 前;如果 offsetA 大于 offsetB,返回 后。
-
如果 nodeA 跟随 nodeB,则如果 (nodeB, offsetB) 相对于 (nodeA, offsetA) 的 位置 是 前,则返回 后,如果是 后,则返回 前。
-
如果 nodeA 是 nodeB 的 祖先:
-
返回 前。
5.3. 接口 AbstractRange
[Exposed =Window ]interface {
AbstractRange readonly attribute Node startContainer ;readonly attribute unsigned long startOffset ;readonly attribute Node endContainer ;readonly attribute unsigned long endOffset ;readonly attribute boolean collapsed ; };
实现 AbstractRange
接口的对象被称为 范围。
为了方便,一个 范围 的 起始节点 是其 起点 的 节点,其 起始偏移量 是其 起点 的 偏移量,其 终点节点 是其 终点 的 节点,其 终点偏移量 是其 终点 的 偏移量。
一个 范围 如果其 起始节点 与其 终点节点 相同,并且其 起始偏移量 与其 终点偏移量 相同,则为 折叠。
node = range . startContainer
- 返回 range 的 起始节点。
offset = range . startOffset
- 返回 range 的 起始偏移量。
node = range . endContainer
- 返回 range 的 终点节点。
offset = range . endOffset
- 返回 range 的 终点偏移量。
collapsed = range . collapsed
- 如果 range 是 折叠的,则返回 true;否则返回 false。
startContainer
的 getter 步骤是返回 this 的 起始节点。
startOffset
的 getter 步骤是返回 this 的 起始偏移量。
endContainer
的 getter 步骤是返回 this 的 终点节点。
endOffset
的 getter 步骤是返回 this 的 终点偏移量。
collapsed
的 getter 步骤是返回 true 如果 this 是 折叠的;否则返回 false。
5.4. 接口 StaticRange
dictionary {
StaticRangeInit required Node ;
startContainer required unsigned long ;
startOffset required Node ;
endContainer required unsigned long ; }; [
endOffset Exposed =Window ]interface :
StaticRange AbstractRange {constructor (StaticRangeInit ); };
init
new StaticRange(init)
构造函数的步骤如下:
-
如果 init["
startContainer
"] 或 init["endContainer
"] 是DocumentType
或Attr
节点,则 抛出 "InvalidNodeTypeError
"DOMException
。 -
将 this 的 起点 设置为 (init["
startContainer
"], init["startOffset
"]) 和 终点 设置为 (init["endContainer
"], init["endOffset
"])。
如果以下所有条件都为真,则 StaticRange
是 有效的:
5.5. 接口 Range
[Exposed =Window ]interface :
Range AbstractRange {constructor ();readonly attribute Node commonAncestorContainer ;undefined setStart (Node ,
node unsigned long );
offset undefined setEnd (Node ,
node unsigned long );
offset undefined setStartBefore (Node );
node undefined setStartAfter (Node );
node undefined setEndBefore (Node );
node undefined setEndAfter (Node );
node undefined collapse (optional boolean =
toStart false );undefined selectNode (Node );
node undefined selectNodeContents (Node );
node const unsigned short = 0;
START_TO_START const unsigned short = 1;
START_TO_END const unsigned short = 2;
END_TO_END const unsigned short = 3;
END_TO_START short compareBoundaryPoints (unsigned short ,
how Range ); [
sourceRange CEReactions ]undefined deleteContents (); [CEReactions ,NewObject ]DocumentFragment extractContents (); [CEReactions ,NewObject ]DocumentFragment cloneContents (); [CEReactions ]undefined insertNode (Node ); [
node CEReactions ]undefined surroundContents (Node ); [
newParent NewObject ]Range cloneRange ();undefined detach ();boolean isPointInRange (Node ,
node unsigned long );
offset short comparePoint (Node ,
node unsigned long );
offset boolean intersectsNode (Node );
node stringifier ; };
实现 Range
接口的对象被称为 实时范围。
修改 树 的算法(特别是 插入、移除、替换数据 和 分割 算法)会修改与该 树 关联的 实时范围。
节点 node 如果满足以下条件,则被认为包含在 实时范围 range 中:node 的 根 是 range 的 根,且 (node, 0) 位于 range 的 起点 之后,(node, node 的 长度) 位于 range 的 终点 之前。
如果节点 node 是 实时范围 的 部分包含 节点,如果它是 起始节点 但不是 终点节点 的包容祖先,或反之亦然。
以下是一些帮助理解这些定义的事实:
-
人们认为在 实时范围 内的内容由所有 包含的 节点 以及可能的 起始节点 和 终点节点 的部分内容组成,如果它们是
CharacterData
节点。 -
包含在 实时范围 中的节点通常不会是连续的,因为包含节点的父节点不一定被包含。
-
然而,包含节点的后代节点和两个包含的兄弟节点之间的兄弟节点也是包含的。
-
如果有包含的节点,第一个包含的节点总是在起始节点之后,最后一个包含的节点总是在终点节点的最后一个后代之前或相等。
-
当且仅当起始节点和终点节点不同,才会存在部分包含的节点。
-
commonAncestorContainer
属性值既不被包含也不被部分包含。 -
如果起始节点是终点节点的祖先,起始节点将是共同的包容祖先。它的一个子节点将是部分包含的,而另一个子节点则是包含的。
-
如果起始节点既不是终点节点的祖先,反之亦然,则共同的包容祖先将与它们都不同。正好两个子节点将是部分包含的,而介于这两个子节点之间的子节点将是包含的。
range = new Range()
- 返回一个新的实时范围。
new Range()
构造器步骤如下:
- 将this的start和end设置为(当前全局对象的关联的
Document
,0)。
- container = range .
commonAncestorContainer
- 返回离文档最远的节点,该节点是range的起始节点和结束节点的祖先。
commonAncestorContainer
获取器步骤如下:
要设置起点或终点为range的边界点 (node, offset),执行以下步骤:
- 如果node是doctype,则抛出 "
InvalidNodeTypeError
"DOMException
。 - 如果offset大于node的长度,则抛出 "
IndexSizeError
"DOMException
。 - 令bp为边界点 (node, offset)。
setStart(node, offset)
方法步骤是将设置起点为this的边界点 (node,
offset)。
setEnd(node, offset)
方法步骤是将设置终点为this的边界点 (node,
offset)。
setStartBefore(node)
方法步骤如下:
- 令parent为node的父节点。
- 如果parent为null,则抛出 "
InvalidNodeTypeError
"DOMException
。 - 设置起点为this的边界点 (parent, node的索引)。
setStartAfter(node)
方法步骤如下:
-
令parent为node的父节点。
-
如果parent为null,则抛出 "
InvalidNodeTypeError
"DOMException
。
setEndBefore(node)
方法步骤如下:
- 令parent为node的父节点。
- 如果parent为null,则抛出 "
InvalidNodeTypeError
"DOMException
。 - 设置终点为this的边界点 (parent, node的索引)。
setEndAfter(node)
方法步骤如下:
-
令parent为node的父节点。
-
如果parent为null,则抛出 "
InvalidNodeTypeError
"DOMException
。
collapse(toStart)
方法步骤如下:如果toStart为true,将终点设置为起点;否则,将起点设置为终点。
要选择range内的node 节点,执行以下步骤:
-
令parent为node的父节点。
-
如果parent为null,则抛出 "
InvalidNodeTypeError
"DOMException
。 -
令index为node的索引。
方法selectNode(node)
的步骤是选择 node在this内。
方法selectNodeContents(node)
的步骤如下:
-
如果node是doctype,则抛出 "
InvalidNodeTypeError
"DOMException
。 -
令length为node的长度。
-
将起点设置为边界点(node, 0)。
-
将终点设置为边界点(node, length)。
方法compareBoundaryPoints(how, sourceRange)
的步骤如下:
-
如果how不是以下之一:
那么抛出一个"
NotSupportedError
"DOMException
。 - 如果this的根与sourceRange的根不同,那么抛出一个"
WrongDocumentError
"DOMException
。 - 如果how是:
START_TO_START
:- 设this point为this的开始。 设other point为sourceRange的开始。
START_TO_END
:- 设this point为this的结束。 设other point为sourceRange的开始。
END_TO_END
:- 设this point为this的结束。 设other point为sourceRange的结束。
END_TO_START
:- 设this point为this的开始。 设other point为sourceRange的结束。
-
如果this point相对于other point的位置是
方法deleteContents()
的步骤如下:
- 设original start node、original start offset、original end node和original end offset为this的开始节点、开始偏移量、结束节点和结束偏移量。
-
如果original start node是original end node并且它是
CharacterData
节点,那么用数据替换节点original start node,偏移量original start offset,计数original end offset减去original start offset,数据为空字符串,然后返回。 - 设nodes to remove为节点的列表,这些节点按树顺序被包含在this中,省略了任何其父节点也被包含在this中的节点。
- 如果original start node是original end node的包含祖先,则将new node设置为original start node,并将new offset设置为original start offset。
- 否则:
-
如果original start node是
CharacterData
节点,那么用数据替换节点original start node,偏移量original start offset,计数为original start node的长度 − original start offset,数据为空字符串。 -
如果original end node是
CharacterData
节点,那么用数据替换节点original end node,偏移量为0,计数为original end offset,数据为空字符串。 - 将开始和结束设置为(new node,new offset)。
要提取一个实时范围 range,请执行以下步骤:
-
设fragment为一个新的
DocumentFragment
节点,其节点文档是range的开始节点的节点文档。 -
如果range是折叠的,则返回fragment。
- 设original start node、original start offset、original end node和original end offset为range的开始节点、开始偏移量、结束节点和结束偏移量。
-
如果original start node是original end node并且它是
CharacterData
节点,那么: - 设common ancestor为original start node。
- 当common ancestor不是original end node的包含祖先时,将common ancestor设置为其自己的父节点。
- 设first partially contained child为null。
- 如果original start node不是original end node的包含祖先,将first partially contained child设置为common ancestor的第一个子节点,它在range中是部分包含的。
- 设last partially contained child为null。
-
如果original end node不是original start node的包含祖先,将last partially contained
child设置为common ancestor的最后一个子节点,它在range中是部分包含的。
这些变量的分配实际上总是有意义的。例如,如果original start node不是original end node的包含祖先,那么original start node本身就在range中是部分包含的,并且它的所有祖先都是,直到common ancestor的一个子节点。common ancestor不能是original start node,因为它必须是original end node的包含祖先。另一个情况类似。此外,请注意,如果两个子节点都已定义,它们永远不会相等。
- 设contained children为common ancestor的所有子节点的列表,它们在range中是包含的,按树顺序排列。
-
如果contained children中的任何成员是文档类型,则抛出一个"
HierarchyRequestError
"DOMException
。我们不必担心第一个或最后一个部分包含的节点,因为文档类型永远不会是部分包含的。它不能是范围的边界点,也不能是任何东西的祖先。
- 如果original start node是original end node的包含祖先,则将new node设置为original start node,并将new offset设置为original start offset。
- 否则:
-
如果first partially contained child是
CharacterData
节点,那么:在这种情况下,first partially contained child是original start node。
- 否则,如果first partially contained child不为null:
- 对于contained children中的每个contained child,追加 contained child到fragment。
-
如果last partially contained child是
CharacterData
节点,那么:在这种情况下,last partially contained child是original end node。
- 否则,如果last partially contained child不为null:
- 将range的开始和结束设置为(new node,new offset)。
- 返回fragment。
方法extractContents()
的步骤是返回提取 this的结果。
要克隆内容一个实时范围 range,请执行以下步骤:
-
设fragment为一个新的
DocumentFragment
节点,其节点文档是range的开始节点的节点文档。 -
如果range是折叠的,则返回fragment。
- 设original start node、original start offset、original end node和original end offset为range的开始节点、开始偏移量、结束节点和结束偏移量。
-
如果original start node是original end node并且它是
CharacterData
节点,那么: - 设common ancestor为original start node。
- 当common ancestor不是original end node的包含祖先时,将common ancestor设置为其自己的父节点。
- 设first partially contained child为null。
- 如果original start node不是original end node的包含祖先,将first partially contained child设置为common ancestor的第一个子节点,它在range中是部分包含的。
- 设last partially contained child为null。
-
如果original end node不是original start node的包含祖先,将last partially contained
child设置为common ancestor的最后一个子节点,它在range中是部分包含的。
这些变量的分配实际上总是有意义的。例如,如果original start node不是original end node的包含祖先,那么original start node本身就在range中是部分包含的,并且它的所有祖先都是,直到common ancestor的一个子节点。common ancestor不能是original start node,因为它必须是original end node的包含祖先。另一个情况类似。此外,请注意,如果两个子节点都已定义,它们永远不会相等。
- 设contained children为common ancestor的所有子节点的列表,这些子节点在range中是包含的,按树顺序排列。
-
如果contained children中的任何成员是文档类型,则抛出一个"
HierarchyRequestError
"DOMException
。我们不必担心第一个或最后一个部分包含的节点,因为文档类型永远不会是部分包含的。它不能是范围的边界点,也不能是任何东西的祖先。
-
如果first partially contained child是
CharacterData
节点,那么:在这种情况下,first partially contained child是original start node。
- 否则,如果first partially contained child不为null:
- 对于contained children中的每个contained child:
-
如果last partially contained child是
CharacterData
节点,那么:在这种情况下,last partially contained child是original end node。
- 否则,如果last partially contained child不为null:
- 返回fragment。
方法cloneContents()
的步骤是返回克隆 this内容的结果。
要插入一个节点 node到一个实时范围 range中,请执行以下步骤:
- 如果range的开始节点是
ProcessingInstruction
或Comment
节点,是Text
节点,其父节点为null,或是node,则抛出一个"HierarchyRequestError
"DOMException
。 - 设referenceNode为null。
- 如果range的开始节点是一个
Text
节点,将referenceNode设置为该Text
节点。 - 否则,将referenceNode设置为子节点的range的开始节点,其索引为开始偏移量,如果没有这样的子节点,则为null。
- 设parent为range的开始节点,如果referenceNode为null,则为referenceNode的父节点。
- 确保预插入的有效性,将node插入parent中,并且位于referenceNode之前。
- 如果range的开始节点是
Text
节点,将referenceNode设置为分割它的结果,偏移量为range的开始偏移量。 - 如果node是referenceNode,将referenceNode设置为其下一个兄弟。
-
如果referenceNode为null,则设newOffset为parent的长度;否则为referenceNode的索引。
-
如果node是
DocumentFragment
节点,则增加newOffset的长度;否则为1。 - 预插入node到parent,位于referenceNode之前。
方法insertNode(node)
的步骤是将node 插入到this中。
方法surroundContents(newParent)
的步骤如下:
-
如果一个非
Text
节点在部分包含在this中,则抛出一个"InvalidStateError
"DOMException
。 -
如果newParent是一个
Document
、DocumentType
或DocumentFragment
节点,则抛出一个"InvalidNodeTypeError
"DOMException
。由于历史原因,
CharacterData
节点不会在此处被检查,最终会作为副作用而抛出。 -
追加fragment到newParent。
方法cloneRange()
的步骤是返回一个新的实时范围,其开始和结束与this相同。
方法detach()
的步骤是什么也不做。其功能(禁用Range
对象)已被移除,但方法本身为了兼容性而保留。
- position = range .
comparePoint(node, offset)
- 如果该点在范围之前,返回 -1;如果该点在范围内,返回 0;如果该点在范围之后,返回 1。
- intersects = range .
intersectsNode(node)
- 返回range是否与node相交。
方法isPointInRange(node, offset)
的步骤如下:
- 如果node的根节点与this的根节点不同,返回false。
- 如果node是文档类型,则抛出一个"
InvalidNodeTypeError
"DOMException
。 - 如果offset大于node的长度,则抛出一个"
IndexSizeError
"DOMException
。 - 如果(node, offset)位于开始之前或结束之后,返回false。
- 返回true。
方法comparePoint(node, offset)
的步骤如下:
- 如果node的根节点与this的根节点不同,则抛出一个"
WrongDocumentError
"DOMException
。 - 如果node是文档类型,则抛出一个"
InvalidNodeTypeError
"DOMException
。 - 如果offset大于node的长度,则抛出一个"
IndexSizeError
"DOMException
。 - 如果(node, offset)位于开始之前,返回-1。
- 如果(node, offset)位于结束之后,返回1。
- 返回0。
方法intersectsNode(node)
的步骤如下:
方法字符串化行为必须执行以下步骤:
方法createContextualFragment()
、
getClientRects()
和getBoundingClientRect()
在其他规范中定义。[DOM-Parsing] [CSSOM-VIEW]
6. 遍历
NodeIterator
和 TreeWalker
对象可以用来过滤和遍历 节点 树。
每个 NodeIterator
和 TreeWalker
对象都有一个相关的 活动标志,用于避免递归调用。它最初是未设置的。
每个 NodeIterator
和 TreeWalker
对象还具有一个相关的 根(一个 节点)、一个 whatToShow(一个位掩码)和一个 过滤器(一个回调函数)。
要过滤 节点 node 在 NodeIterator
或 TreeWalker
对象
traverser 中,执行以下步骤:
-
如果 traverser 的 活动标志 已设置,则抛出一个 "
InvalidStateError
"DOMException
。 -
让 n 为 node 的
nodeType
属性值减 1。 -
如果 traverser 的 whatToShow 中第 nth 位(其中 0 是最低有效位)未设置,则返回
FILTER_SKIP
。 -
如果 traverser 的 过滤器 为空,则返回
FILTER_ACCEPT
。 -
设置 traverser 的 活动标志。
-
让 result 为使用 traverser 的 过滤器,"acceptNode" 和 « node » 调用用户对象的操作的返回值。如果此操作抛出异常,则取消设置 traverser 的 活动标志 并重新抛出异常。
-
取消设置 traverser 的 活动标志。
-
返回 result。
6.1.
接口 NodeIterator
[Exposed =Window ]interface { [
NodeIterator SameObject ]readonly attribute Node root ;readonly attribute Node referenceNode ;readonly attribute boolean pointerBeforeReferenceNode ;readonly attribute unsigned long whatToShow ;readonly attribute NodeFilter ?filter ;Node ?nextNode ();Node ?previousNode ();undefined detach (); };
NodeIterator
对象可以通过 createNodeIterator()
方法在 Document
对象上创建。
每个 NodeIterator
对象都有一个相关的 迭代器集合,
它是一个以 NodeIterator
对象的 根 为根的 集合,其过滤器匹配任何 节点。
每个 NodeIterator
对象还有一个相关的 参考(一个 节点)和
指针在参考前(一个布尔值)。
如前所述,NodeIterator
对象还有一个相关的 活动标志、根、whatToShow 和 过滤器。
给定一个 nodeIterator 和 toBeRemovedNode,NodeIterator
移除前步骤 如下:
-
如果 toBeRemovedNode 不是 nodeIterator 的 参考 的 包含祖先,或 toBeRemovedNode 是 nodeIterator 的 根,则返回。
-
如果 nodeIterator 的 指针在参考前 为 true,则:
-
将 nodeIterator 的 参考 设置为 toBeRemovedNode 的 父节点,如果 toBeRemovedNode 的 前一个兄弟节点 为 null,则设置为 toBeRemovedNode 的 前一个兄弟节点 的在 树顺序 中最后出现的 包含后代。
referenceNode
获取器
步
骤是返回 this 的 参考。
pointerBeforeReferenceNode
获取器
步骤是返回 this 的 指针在参考前。
whatToShow
获取器步骤是
返回 this 的 whatToShow。
给定一个 NodeIterator
对象 iterator 和一个方向 direction,遍历 步骤如下:
-
令 node 为 iterator 的 参考。
-
令 beforeNode 为 iterator 的 指针在参考前。
-
当条件成立时,执行以下步骤:
-
根据 direction 分支:
-
令 result 为 过滤 node 在 iterator 中的结果。
-
如果 result 为
FILTER_ACCEPT
, 则 终止循环。
-
-
将 iterator 的 参考 设置为 node。
-
将 iterator 的 指针在参考前 设置为 beforeNode。
-
返回 node。
nextNode()
方法步骤是
返回使用 遍历 this 和 next 的结果。
previousNode()
方法步骤是返回使用 遍历 this 和
previous 的结果。
detach()
方法步骤是
不做任何操作。其功能(禁用 NodeIterator
对象)已被移除,但该方法
本身为了兼容性保留。
6.2.
接口 TreeWalker
[Exposed =Window ]interface { [
TreeWalker SameObject ]readonly attribute Node root ;readonly attribute unsigned long whatToShow ;readonly attribute NodeFilter ?filter ;attribute Node currentNode ;Node ?parentNode ();Node ?firstChild ();Node ?lastChild ();Node ?previousSibling ();Node ?nextSibling ();Node ?previousNode ();Node ?nextNode (); };
TreeWalker
对象可以通过 createTreeWalker()
方法在 Document
对象上创建。
每个 TreeWalker
对象都有一个相关的 当前(一个 节点)。
如前所述,TreeWalker
对象有一个相关的 根、whatToShow
和
过滤器。
whatToShow
获取器步骤
是
返回 this 的
whatToShow。
currentNode
获取器步骤
是
返回 this 的 当前。
currentNode
设置器步骤是将 this 的
当前 设置为给定值。
parentNode()
方法步骤
是:
-
返回 null。
给定一个 walker 和 type,遍历子节点 步骤如下:
-
令 node 为 walker 的 当前。
-
如果 type 是 first,则将 node 设置为其 第一个子节点;如果 type 是 last,则将 node 设置为其 最后一个子节点。
-
当 node 非空时:
-
令 result 为 过滤 node 在 walker 中的结果。
-
如果 result 是
FILTER_ACCEPT
, 则将 walker 的 当前 设置为 node 并返回 node。 -
如果 result 是
FILTER_SKIP
, 则: -
当 node 非空时:
-
-
返回 null。
firstChild()
方法步骤
是
通过 遍历
子节点 使用 this 和 first。
lastChild()
方法步骤
是
通过 遍历
子节点 使用 this 和 last。
给定一个 walker 和 type,遍历 兄弟节点 步骤如下:
-
令 node 为 walker 的 当前。
-
如果 node 是 根,则返回 null。
-
当条件成立时,执行以下步骤:
-
如果 type 是 next,则令 sibling 为 node 的 下一个兄弟节点;如果 type 是 previous,则令 sibling 为 node 的 上一个兄弟节点。
-
当 sibling 非空时:
-
将 node 设置为 sibling。
-
令 result 为 过滤 node 在 walker 中的结果。
-
如果 result 是
FILTER_ACCEPT
, 则将 walker 的 当前 设置为 node 并返回 node。 -
如果 type 是 next,则将 sibling 设置为 node 的 第一个子节点;如果 type 是 previous,则将 sibling 设置为 node 的 最后一个子节点。
-
如果 result 是
FILTER_REJECT
或 sibling 为空, 则将 sibling 设置为 node 的 下一个兄弟节点(如果 type 是 next),或将 sibling 设置为 node 的 上一个兄弟节点(如果 type 是 previous)。
-
-
将 node 设置为其 父节点。
-
如果 node 为 null 或 walker 的 根,则返回 null。
-
如果 过滤 node 在 walker 中的结果是
FILTER_ACCEPT
, 则返回 null。
-
nextSibling()
方法
步骤
是通过 遍历
兄弟节点 使用 this 和 next。
previousSibling()
方法
步骤是通过 遍历
兄弟节点 使用 this 和 previous。
previousNode()
方法
步骤
是:
-
返回 null。
nextNode()
方法步骤是:
-
令 result 为
FILTER_ACCEPT
。 -
当条件成立时,执行以下步骤:
-
当 result 不是
FILTER_REJECT
且 node 有 子节点 时: -
令 sibling 为 null。
-
令 temporary 为 node。
-
当 temporary 非空时,执行以下步骤:
-
如果 result 是
FILTER_ACCEPT
, 则将 this 的 当前 设置为 node 并返回 node。
-
6.3.
接口 NodeFilter
[Exposed =Window ]callback interface { // Constants for acceptNode()
NodeFilter const unsigned short FILTER_ACCEPT = 1;const unsigned short FILTER_REJECT = 2;const unsigned short FILTER_SKIP = 3; // Constants for whatToShowconst unsigned long SHOW_ALL = 0xFFFFFFFF;const unsigned long SHOW_ELEMENT = 0x1;const unsigned long SHOW_ATTRIBUTE = 0x2;const unsigned long SHOW_TEXT = 0x4;const unsigned long SHOW_CDATA_SECTION = 0x8;const unsigned long = 0x10; // legacy
SHOW_ENTITY_REFERENCE const unsigned long = 0x20; // legacy
SHOW_ENTITY const unsigned long SHOW_PROCESSING_INSTRUCTION = 0x40;const unsigned long SHOW_COMMENT = 0x80;const unsigned long SHOW_DOCUMENT = 0x100;const unsigned long SHOW_DOCUMENT_TYPE = 0x200;const unsigned long SHOW_DOCUMENT_FRAGMENT = 0x400;const unsigned long = 0x800; // legacy
SHOW_NOTATION unsigned short (
acceptNode Node ); };
node
NodeFilter
对象可以用作 NodeIterator
和 TreeWalker
对象的 过滤器,并且还为它们的 whatToShow
位掩码提供常量。NodeFilter
对象通常实现为
一个 JavaScript 函数。
这些常量可用作 过滤器 的返回值:
FILTER_ACCEPT
(1);FILTER_REJECT
(2);FILTER_SKIP
(3)。
这些常量可用于 whatToShow:
SHOW_ALL
(4294967295, 十六进制为 FFFFFFFF);SHOW_ELEMENT
(1);SHOW_ATTRIBUTE
(2);SHOW_TEXT
(4);SHOW_CDATA_SECTION
(8);SHOW_PROCESSING_INSTRUCTION
(64, 十六进制为 40);SHOW_COMMENT
(128, 十六进制为 80);SHOW_DOCUMENT
(256, 十六进制为 100);SHOW_DOCUMENT_TYPE
(512,十六进制为 200);SHOW_DOCUMENT_FRAGMENT
(1024,十六进制为 400)。
7. 集合
是的,DOMTokenList
这个名称确实是遗留问题的不幸产物。
7.1.
接口 DOMTokenList
[Exposed =Window ]interface {
DOMTokenList readonly attribute unsigned long length ;getter DOMString ?item (unsigned long );
index boolean contains (DOMString ); [
token CEReactions ]undefined add (DOMString ...); [
tokens CEReactions ]undefined remove (DOMString ...); [
tokens CEReactions ]boolean toggle (DOMString ,
token optional boolean ); [
force CEReactions ]boolean replace (DOMString ,
token DOMString );
newToken boolean supports (DOMString ); [
token CEReactions ]stringifier attribute DOMString value ;iterable <DOMString >; };
A DOMTokenList
对象有一个关联的 token 集合(一个 有序集合),初始为空。
A DOMTokenList
对象还关联了一个 元素 和一个 属性的 本地名称。
规范 可能会为 DOMTokenList
的
关联 属性的 本地名称 定义 支持的标记。
A DOMTokenList
对象的给定 token 的 验证步骤 是:
A DOMTokenList
对象的 更新步骤 是:
A DOMTokenList
对象的 序列化步骤 是返回运行 获取属性值 给定关联的
元素 和
关联的 属性 的 本地名称 的结果。
A DOMTokenList
对象对其关联的 属性更改步骤 如下:
-
如果 localName 是关联属性的 本地名称, namespace 为 null,且 value 为 null,则 清空 token 集合。
-
否则,如果 localName 是关联属性的 本地名称, namespace 为 null,则将 token 集合 设置为 解析 value。
当创建 DOMTokenList
对象时:
-
令 element 为关联的 元素。
-
令 localName 为关联属性的 本地名称。
-
令 value 为 获取属性值 给定 element 和 localName 的结果。
-
为 element,localName,value,value 和 null 运行 属性更改步骤。
tokenlist .
length
-
返回标记的数量。
tokenlist .
item(index)
tokenlist[index]
-
返回索引为 index 的标记。
tokenlist .
contains(token)
-
如果 token 存在,则返回 true;否则返回 false。
tokenlist . add(tokens…)
-
添加传递的所有参数,已存在的除外。
如果其中一个参数为空字符串,则抛出 "
SyntaxError
"DOMException
。如果其中一个参数包含任何 ASCII 空白符,则抛出 "
InvalidCharacterError
"DOMException
。 tokenlist . remove(tokens…)
-
移除传递的参数,如果它们存在。
如果其中一个参数为空字符串,则抛出 "
SyntaxError
"DOMException
。如果其中一个参数包含任何 ASCII 空白符,则抛出 "
InvalidCharacterError
"DOMException
。 tokenlist . toggle(token [, force])
-
如果没有给定 force,则“切换” token,如果它存在则移除,如果不存在则添加。如果 force 为 true,则添加 token (与
add()
相同)。 如果 force 为 false,则移除 token(与remove()
相同)。如果 token 现在存在,则返回 true;否则返回 false。
如果 token 为空,则抛出 "
SyntaxError
"DOMException
。如果 token 包含任何空格,则抛出 "
InvalidCharacterError
"DOMException
。 tokenlist . replace(token, newToken)
-
用 newToken 替换 token。
如果 token 被 newToken 替换,则返回 true;否则返回 false。
如果其中一个参数为空字符串,则抛出 "
SyntaxError
"DOMException
。如果其中一个参数包含任何 ASCII 空白符,则抛出 "
InvalidCharacterError
"DOMException
。 tokenlist . supports(token)
-
如果 token 在关联属性的支持标记中,则返回 true。 否则返回 false。
如果关联属性没有定义支持标记,则抛出
TypeError
。 tokenlist .
value
-
将关联的集合作为字符串返回。
可以设置,来更改关联的属性。
The length
属性的 getter
必须返回 this 的
token 集合的 大小。
对象的 支持的属性索引 是 从零到对象的 token 集合的 大小减一的数字,除非 token 集合 为空, 在这种情况下,没有 支持的属性索引。
The item(index)
方法步骤是:
The contains(token)
方法步骤是
如果 this 的 token
集合[token] 存在;
否则返回 false。
The add(tokens…)
方法步骤是:
-
对于 tokens 中的每个 token:
-
如果 token 是空字符串,则 抛出 一个 "
SyntaxError
"DOMException
。 -
如果 token 包含任何 ASCII 空白符,则 抛出 一个 "
InvalidCharacterError
"DOMException
。
-
-
运行 更新 步骤。
The remove(tokens…)
方法步骤是:
-
对于 tokens 中的每个 token:
-
如果 token 是空字符串,则 抛出 一个 "
SyntaxError
"DOMException
。 -
如果 token 包含任何 ASCII 空白符,则 抛出 一个 "
InvalidCharacterError
"DOMException
。
-
-
运行 更新 步骤。
The toggle(token, force)
方法步骤是:
-
如果 token 是空字符串,则 抛出 一个 "
SyntaxError
"DOMException
。 -
如果 token 包含任何 ASCII 空白符,则 抛出 一个 "
InvalidCharacterError
"DOMException
。 -
否则,如果 force 没有给定或为 true,追加 token 到 this 的 token 集合 中,运行 更新步骤, 并返回 true。
-
返回 false。
为了 Web 兼容性,并不总是为 toggle()
运行 更新步骤。
The replace(token, newToken)
方法步骤是:
-
如果 token 或 newToken 为空字符串,则 抛出 一个 "
SyntaxError
"DOMException
。 -
如果 token 或 newToken 包含任何 ASCII 空白符,则 抛出 一个 "
InvalidCharacterError
"DOMException
。 -
运行 更新 步骤。
-
返回 true。
为了 Web 兼容性,并不总是为 replace()
运行 更新步骤。
The supports(token)
方法步骤是:
-
令 result 为调用 验证步骤, 传递 token。
-
返回 result。
The value
属性必须返回
运行 this 的 序列化步骤 的结果。
设置 value
属性必须为关联的 元素
使用关联的 属性的 本地名称 设置属性值并
使用给定的值。
8. XPath
DOM Level 3 XPath 定义了一个用于评估XPath 1.0表达式的 API。 这些 API 被广泛实现,但未得到维护。接口定义在此保留,以便在 Web IDL 发生变化时可以更新。 完整的这些 API 的定义仍然是必要的,此类工作已被跟踪并可以在 whatwg/dom#67 中贡献。 [DOM-Level-3-XPath] [XPath] [WEBIDL]
8.1.
接口 XPathResult
[Exposed =Window ]interface {
XPathResult const unsigned short = 0;
ANY_TYPE const unsigned short = 1;
NUMBER_TYPE const unsigned short = 2;
STRING_TYPE const unsigned short = 3;
BOOLEAN_TYPE const unsigned short = 4;
UNORDERED_NODE_ITERATOR_TYPE const unsigned short = 5;
ORDERED_NODE_ITERATOR_TYPE const unsigned short = 6;
UNORDERED_NODE_SNAPSHOT_TYPE const unsigned short = 7;
ORDERED_NODE_SNAPSHOT_TYPE const unsigned short = 8;
ANY_UNORDERED_NODE_TYPE const unsigned short = 9;
FIRST_ORDERED_NODE_TYPE readonly attribute unsigned short ;
resultType readonly attribute unrestricted double ;
numberValue readonly attribute DOMString ;
stringValue readonly attribute boolean ;
booleanValue readonly attribute Node ?;
singleNodeValue readonly attribute boolean ;
invalidIteratorState readonly attribute unsigned long ;
snapshotLength Node ?();
iterateNext Node ?(
snapshotItem unsigned long ); };
index
8.2.
接口 XPathExpression
[Exposed =Window ]interface { // XPathResult.ANY_TYPE = 0
XPathExpression XPathResult (
evaluate Node ,
contextNode optional unsigned short = 0,
type optional XPathResult ?=
result null ); };
8.3.
混入 XPathEvaluatorBase
callback interface {
XPathNSResolver DOMString ?(
lookupNamespaceURI DOMString ?); };
prefix interface mixin { [
XPathEvaluatorBase NewObject ]XPathExpression (
createExpression DOMString ,
expression optional XPathNSResolver ?=
resolver null );Node createNSResolver (Node ); // legacy // XPathResult.ANY_TYPE = 0
nodeResolver XPathResult (
evaluate DOMString ,
expression Node ,
contextNode optional XPathNSResolver ?=
resolver null ,optional unsigned short = 0,
type optional XPathResult ?=
result null ); };Document includes XPathEvaluatorBase ;
The createNSResolver(nodeResolver)
方法步骤是返回 nodeResolver。
此方法仅因历史原因存在。
8.4.
接口 XPathEvaluator
[Exposed =Window ]interface {
XPathEvaluator (); };
constructor XPathEvaluator includes XPathEvaluatorBase ;
由于历史原因,您既可以构造 XPathEvaluator
也可以在 Document
上访问相同的方法。
9. XSLT
XSL Transformations (XSLT) 是一种将 XML 文档转换为其他 XML 文档的语言。 本节定义的 API 已被广泛实现,并在此保留,以便在 Web IDL 发生变化时可以更新。 这些 API 的完整定义仍然是必要的,此类工作已被跟踪并可以在 whatwg/dom#181 中贡献。 [XSLT]
9.1.
接口 XSLTProcessor
[Exposed =Window ]interface {
XSLTProcessor ();
constructor undefined (
importStylesheet Node ); [
style CEReactions ]DocumentFragment (
transformToFragment Node ,
source Document ); [
output CEReactions ]Document (
transformToDocument Node );
source undefined ([
setParameter LegacyNullToEmptyString ]DOMString ,
namespaceURI DOMString ,
localName any );
value any ([
getParameter LegacyNullToEmptyString ]DOMString ,
namespaceURI DOMString );
localName undefined ([
removeParameter LegacyNullToEmptyString ]DOMString ,
namespaceURI DOMString );
localName undefined ();
clearParameters undefined (); };
reset
10. 安全和隐私考虑
此标准没有已知的安全或隐私考虑。
11. 历史
此标准曾包含多个已被移除的接口和接口成员。
这些接口已被移除:
DOMConfiguration
DOMError
DOMErrorHandler
DOMImplementationList
DOMImplementationSource
DOMLocator
DOMObject
DOMUserData
Entity
EntityReference
MutationEvent
MutationNameEvent
NameList
Notation
RangeException
TypeInfo
UserDataHandler
这些接口成员已被移除:
Attr
-
schemaTypeInfo
isId
Document
-
createEntityReference()
xmlEncoding
xmlStandalone
xmlVersion
strictErrorChecking
domConfig
normalizeDocument()
renameNode()
DocumentType
-
entities
notations
internalSubset
DOMImplementation
-
getFeature()
Element
-
schemaTypeInfo
setIdAttribute()
setIdAttributeNS()
setIdAttributeNode()
Node
-
isSupported
getFeature()
getUserData()
setUserData()
NodeIterator
-
expandEntityReferences
Text
-
isElementContentWhitespace
replaceWholeText()
TreeWalker
-
expandEntityReferences
致谢
多年来,许多人为使 DOM 更具互操作性作出了贡献,从而促进了该标准的目标。同样,许多人也为使该标准发展至今做出了帮助。
因此,特别感谢以下人士: Adam Klein, Adrian Bateman, Ahmid snuggs, Alex Komoroske, Alex Russell, Alexey Shvayka, Andreu Botella, Anthony Ramine, Arkadiusz Michalski, Arnaud Le Hors, Arun Ranganathan, Benjamin Gruenbaum, Björn Höhrmann, Boris Zbarsky, Brandon Payton, Brandon Slade, Brandon Wallace, Brian Kardell, C. Scott Ananian, Cameron McCormack, Chris Dumez, Chris Paris, Chris Rebert, Cyrille Tuzi, Dan Burzo, Daniel Clark, Daniel Glazman, Darin Fisher, David Bruant, David Flanagan, David Håsäther, David Hyatt, Deepak Sherveghar, Dethe Elza, Dimitri Glazkov, Domenic Denicola, Dominic Cooney, Dominique Hazaël-Massieux, Don Jordan, Doug Schepers, Edgar Chen, Elisée Maurer, Elliott Sprehn, Emilio Cobos Álvarez, Eric Bidelman, Erik Arvidsson, François Remy, Gary Kacmarcik, Gavin Nicol, Giorgio Liscio, Glen Huang, Glenn Adams, Glenn Maynard, Hajime Morrita, Harald Alvestrand, Hayato Ito, Henri Sivonen, Hongchan Choi, Hunan Rostomyan, Ian Hickson, Igor Bukanov, Jacob Rossi, Jake Archibald, Jake Verbaten, James Graham, James Greene, James M Snell, James Robinson, Jeffrey Yasskin, Jens Lindström, Jeremy Davis, Jesse McCarthy, Jinho Bang, João Eiras, Joe Kesselman, John Atkins, John Dai, Jonas Sicking, Jonathan Kingston, Jonathan Robie, Joris van der Wel, Joshua Bell, J. S. Choi, Jungkee Song, Justin Summerlin, Kagami Sascha Rosylight, 呂康豪 (Kang-Hao Lu), 田村健人 (Kent TAMURA), Kevin J. Sung, Kevin Sweeney, Kirill Topolyan, Koji Ishii, Lachlan Hunt, Lauren Wood, Luca Casonato, Luke Zielinski, Magne Andersson, Majid Valipour, Malte Ubl, Manish Goregaokar, Manish Tripathi, Marcos Caceres, Mark Miller, Martijn van der Ven, Mason Freed, Mats Palmgren, Mounir Lamouri, Michael Stramel, Michael™ Smith, Mike Champion, Mike Taylor, Mike West, Nicolás Peña Moreno, Nidhi Jaju, Ojan Vafai, Oliver Nightingale, Olli Pettay, Ondřej Žára, Peter Sharpe, Philip Jägenstedt, Philippe Le Hégaret, Piers Wombwell, Pierre-Marie Dartus, prosody—Gab Vereable Context(, Rafael Weinstein, Rakina Zata Amni, Richard Bradshaw, Rick Byers, Rick Waldron, Robbert Broersma, Robin Berjon, Roland Steiner, Rune F. Halvorsen, Russell Bicknell, Ruud Steltenpool, Ryosuke Niwa, Sam Dutton, Sam Sneddon, Samuel Giles, Sanket Joshi, Scott Haseley, Sebastian Mayr, Seo Sanghyeon, Sergey G. Grekhov, Shiki Okasaka, Shinya Kawanaka, Simon Pieters, Stef Busking, Steve Byrne, Stig Halvorsen, Tab Atkins, Takashi Sakamoto, Takayoshi Kochi, Theresa O’Connor, Theodore Dubois, timeless, Timo Tijhof, Tobie Langel, Tom Pixley, Travis Leithead, Trevor Rowbotham, triple-underscore, Tristan Fraipont, Veli Şenol, Vidur Apparao, Warren He, Xidorn Quan, Yash Handa, Yehuda Katz, Yoav Weiss, Yoichi Osato, Yoshinori Sano, Yu Han, Yusuke Abe, 和 Zack Weinberg, 感谢你们的出色贡献!
本标准由Anne van Kesteren (Apple, annevk@annevk.nl)编写,并得到了Aryeh Gregor (ayg@aryeh.name)和Ms2ger (ms2ger@gmail.com)的实质性贡献。
知识产权
版权 © WHATWG (Apple, Google, Mozilla, Microsoft)。本作品采用知识共享署名 4.0 国际许可协议进行许可。在将其部分内容纳入源代码时,该部分内容在源代码中按照BSD 3-Clause 许可证进行许可。
这是现行标准。对专利审查版本感兴趣的读者应查看现行标准审查草案。