* [CODE(DOMi)@en[Element]] インターフェイス (DOM) [2] [CODE(DOMi)[Element]] 界面は、 [[HTML]]・[[XML]] の[[要素]]のための機能を提供します。1つの [CODE(DOM)[Element]] 節が HTML/XML 文書の1つの要素に対応します。 [1] [[DOM1]] では、[RUBYB[要素節] [[CODE(DOM)[Element]] node]]は次の種類の[[節]]を子供に出来ます。 -[[Element]] -[[Text]] -[[Comment]] -[[ProcessingInstruction]] -[[CDATASection]] -[[EntityReference]] [3] [CODE(DOMi)[[[Node]]]] 界面を継承して、 ,[CODE(DOMa)@en[[[all]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[applyElement]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[attachEvent]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[behaviorUrns]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[blur]]]],"[CODE(DOMi)@en[[[HTMLControlElement]]]] 他 ([[Trident]]), [CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[canHaveChildren]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[clearAttributes]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[click]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[WinIE 4]])" ,[CODE(DOMa)@en[[[clientHeight]]]],"[CODE(DOMi)@en[[[HTMLControlElement]]]] 他 ([[Trident]]), [CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[clientLeft]]]],"[CODE(DOMi)@en[[[HTMLControlElement]]]] 他 ([[Trident]]), [CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[clientTop]]]],"[CODE(DOMi)@en[[[HTMLControlElement]]]] 他 ([[Trident]]), [CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[clientWidth]]]],"[CODE(DOMi)@en[[[HTMLControlElement]]]] 他 ([[Trident]]), [CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[componentFromPoint]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[contains]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[currentStyle]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[detachEvent]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[document]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[doScroll]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[dragDrop]]]],"[CODE(DOMi)@en[[[HTMLElement3]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[FireEvent]]]],"[CODE(DOMi)@en[[[HTMLElement3]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[focus]]]],"[CODE(DOMi)@en[[[HTMLControlElement]]]] 他 ([[Trident]]), [CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[getAdjacentText]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[getBoundingClientRects]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[getClientRects]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[getExpression]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[glyphMode]]]],"[CODE(DOMi)@en[[[HTMLElement3]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[hideFocus]]]],"[CODE(DOMi)@en[[[HTMLElement3]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[inflateBlock]]]],"[CODE(DOMi)@en[[[HTMLElement3]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[innerText]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[insertAdjacentElement]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[insertAdjacentText]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[isTextEdit]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[tagName]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[WinIE 4]]), [CODE(DOMi)@en[[[Element]]]] ([[DOM水準1中核]])" ,[CODE(DOMm)@en[[[getAttribute]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[WinIE 4]]), [CODE(DOMi)@en[[[Element]]]] ([[DOM水準1中核]])" ,method,[CODE(DOMm)[[[getAttributeNS]]]],属性値を取得 ,[DOM2] ,[CODE(DOMm)[[[setAttribute]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[WinIE 4]]), [CODE(DOMi)@en[[[Element]]]] ([[DOM水準1中核]])" ,method,[CODE(DOMm)[[[setAttributeNS]]]],属性を設定 ,[DOM2] ,[CODE(DOMm)[[[removeAttribute]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[WinIE 4]]), [CODE(DOMi)@en[[[Element]]]] ([[DOM水準1中核]])" ,method,[CODE(DOMm)[[[removeAttributeNS]]]],属性を削除 ,[DOM2] ,method,[CODE(DOMm)[[[hasAttribute]]]] ,属性の存在 ,[DOM2] ,method,[CODE(DOMm)[[[hasAttributeNS]]]],属性の存在 ,[DOM2] ,method,[CODE(DOMm)[[[getAttributeNode]]]],属性節を取得 ,[DOM1] ,method,[CODE(DOMm)[[[getAttributeNodeNS]]]],属性節を取得,[DOM2] ,method,[CODE(DOMm)[[[setAttributeNode]]]],属性節を設定 ,[DOM1] ,method,[CODE(DOMm)[[[setAttributeNodeNS]]]],属性節を設定,[DOM2] ,method,[CODE(DOMm)[[[removeAttributeNode]]]],属性節を削除,[DOM1] ,method,[CODE(DOMm)[[[removeAttributeNodeNS]]]],属性節を削除,[DOM2] ,method,[CODE(DOMm)[[[getElementsByTagName]]]],要素型名を指定して要素群を取得,[DOM1] ,method,[CODE(DOMm)[[[getElementsByTagNameNS]]]],要素型名を指定して要素群を取得,[DOM2] ,[CODE(DOMm)@en[[[mergeAttributes]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,method,[CODE(DOMm)[[[normalize]]]],子節を正規化,"[DOM1], [DOM1ERRATA]" ,[CODE(DOMa)@en[[[offsetLeft]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[offsetParent]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[offsetTop]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[offsetWidth]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[outerText]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[parentTextEdit]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[readyState]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[readyStateValue]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[recordNumber]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[releaseCapture]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[removeBehavior]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[removeExpression]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[replaceAdjacentText]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[runtimeStyle]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[scopeName]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[scrollHeight]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[scrollIntoView]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[scrollLeft]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[scrollTop]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[scrollWidth]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[setActive]]]],"[CODE(DOMi)@en[[[HTMLElement3]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[setCapture]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMm)@en[[[setExpression]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[sourceIndex]]]],"[CODE(DOMi)@en[[[HTMLElement]]]] ([[Trident]])" ,[CODE(DOMa)@en[[[tagUrn]]]],"[CODE(DOMi)@en[[[HTMLElement2]]]] ([[Trident]])" ** 要素のサブインターフェイス [23] [CODE(DOMi)@en[[[Element]]]] が実装しなければならない [[DOM]] [[インターフェイス]]について、 [[DOM Standard]] には特に規定はありません。 [24] [[HTML Standard]] は、その定義において示された [[DOM]] [[インターフェイス]]を実装しなければ[['''ならない''']]としています [SRC[>>28, >>25]]。 更に [[HTML構文解析器]]の挙動についても同様の規定があります [SRC[>>26]]。 [REFS[ - [28] [CITE@en-US-x-hixie[HTML Standard]] ([TIME[2012-12-31 05:55:07 +09:00]] 版) - [25] [CITE@en-US-x-hixie[HTML Standard]] ([TIME[2012-12-31 05:55:07 +09:00]] 版) - [26] [CITE@en-US-x-hixie[HTML Standard]] ([TIME[2012-12-31 05:55:07 +09:00]] 版) ]REFS] ;; [29] [[XSLT]] 等意味的に異なった解釈がなされる文脈の [[HTML要素]]でも同様に実装しなければならないとされており [SRC[>>28]]、 従ってどの[[インターフェイス]]を実装する必要があるかは[[要素]]の[[名前空間]]と[[局所名]]により機械的に定まります。 ;; [27] [[W3C DOM]] 時代も同様で、 [[DOM Core]] では特に規定がなく、 [[DOM HTML]] でどの[[インターフェイス]]と[[要素]]が対応関係にあるかが述べられていました。 ** 歴史 -[DOM1] ''Document Object Model (Core) Level 1'' -[DOM2] ''Document Object Model Core'' -[4] Method [CODE(DOMm)[normalize]] は、 DOM 2 で界面 [CODE(DOMi)[Node]] に移動しました。 - [5] [CODE(DOMi)[Node]] 界面では [CODE(DOMm)[[[hasAttributes]]]] method も定義されています (DOM 2)。 [CODE(DOMm)[hasAttribute]] との違いに注意。 [7] [CITE[IRC logs: freenode / #whatwg / 20110802]] ( ([TIME[2011-08-13 13:39:31 +09:00]] 版)) [8] [CITE[IRC logs: freenode / #whatwg / 20111011]] ( ([TIME[2011-10-12 00:08:40 +09:00]] 版)) [9] [CITE@en-GB-hixie[Web Controls 1.0]] ( ([TIME[2004-11-09 08:49:52 +09:00]] 版)) [10] [CITE@en-GB-hixie[Web Applications Markup Language 1.0]] ( ([TIME[2004-04-08 02:39:12 +09:00]] 版)) ** メモ [6] [PRE[ Interface ElementExtended Methods getId Returns one of identifiers of the element. If the element does not have any identifier, "null" is returned. Note that an identifier might not be a valid XML name or might not be unique in the document, particularlly in case the original document is invalid. No Parameter Return Value DOMString An identifier of the element, or "null" if there is no identifier. No Exception ]PRE] * 要素 (SGML) [FIG[ [11] > :(284) 要素 (element): [[文書型宣言]]によって定義される階層構造の構成要素。 [SRC[[[JIS X 4151]]-1992 3.]] -備考1. 通常は、[[開始タグ]]及び[[終了タグ]]である[[記述的マーク]]によって[[文書実現値]]の中で識別される。 - 2. 要素は、特定の[[要素型]]に分類される。 ]FIG] [12] 循環定義のように見えますが、おそらく原文では[Q[構成要素]]が [Q[component]] かなにかなのでしょう。 [13] [FIG[ - [CODE(ABNF)[[DFN[要素]] := [ [[開始タグ]] ] [[内容]] [ [[終了タグ]] ] ;; JIS X 4151‐1992 (13) より]] ]FIG] 開始タグ、終了タグが省略できるのは、それぞれ特定の条件を満たす場合のみです。 詳しくはそれぞれの説明を参照してください。また、 [[強制空要素]]では内容が必ず空になります。 [FIG[ [14] > this International Standard [INS[([[ISO/IEC 15445]]:2000)]] makes a distinction between an individual element with a given generic identifier and the class of all such elements. The class is called an [DFN[element type]], the instance is called an [DFN[element]] and the generic identifier is called an [DFN[element type name]]. [SRC[[[ISO‐HTML]] ]] > この国際規格は個々の要素と[[共通識別子]]とそのような要素のすべての[[級]]を区別します。 級は[DFN[要素型]]と呼び、[[実現値]]は[DFN[要素]]と呼び、 共通識別子は[DFN[要素型名]]と呼びます。 ]FIG] [FIG[ [15] > :[RUBYB[要素][element]]: 要素は [[DTD]] で宣言された[[文書]]の構造化の単位です。 [[要素]]の[[内容模型]]は [[DTD]] で定義されており、 追えて[[意味]]が自然言語文による要素の説明で定義されているかもしれません。 [SRC[XHTML 1.0 2.2]] ]FIG] [FIG[ [16] > :[RUBYB[要素][element]]: [[要素型]]の[[実現値]]。 [SRC[XHTML m12n Term]] ]FIG] ** 仕様書 [REFS[ - [18] [[XHTML 1.0]] --[CITE[2.2. General Terms]] -[19] [[XHTML m12n]] --[XHTML m12n Term] [CSECTION[2. Terms and Definitions]] ]REFS] ** 要素、要素型、要素型名、タグ [17] [DFN[[RUBY[[[要素]]][ようそ]@en[element]]]]とは、 [[文書]]の構造上の単位です。 [[要素]]は[[要素型]]の[[実現値]]です。 [DFN[[RUBY[[[要素型]]][ようそがた]@en[element type]]]]は、 [[要素]]の分類です。 [DFN[[RUBY[[[要素型名]]][ようそがためい]@en[element type name]]]]は、 [[要素型]]を識別するための[[名前]]です。 [DFN[[RUBYB[[[タグ]]]@en[tag]]]]は、 [[実体]]中で[[要素]]のはじめや終わりを識別するための記号列です。 これらはしばしば混同され、時には厳密な区別が意味を成さない場面もありますが、 多くの場合には分けて考えるべきものです。特に、 構造上の範囲である[[要素]]と、構造上の位置を示す[[タグ]]を混同しないことは重要です。 ** 体系と要素 [20] ある要素は、複数の[[体系]]における[[要素形式]]に同時に適合することができますが、 一つの体系の複数の要素形式に同時に適合することはできません。 ただし、ある要素が (その属性に関して) 複数または一つの体系の、 複数の[[属性形式]]に適合することは、 (特に禁止されていなければ) 可能です。 *** 仕様書 [REFS[ - [21] [[ISO/IEC 10744]]:1997 -- A.3.1.1 ]REFS] * 要素情報項目 (XML 情報集合) [10] [[Atom]] や [[AtomPub]] の仕様書では、「[[要素]]」は[[要素情報項目]]を意味します。 ** 仕様書 [REFS[ - [22] [CITE@en[RFC 5023 - The Atom Publishing Protocol]] ([TIME[2008-11-20 18:52:14 +09:00]] 版) ]REFS]