2016-12-19 5 views
0

は、私はこのように、createElementNSを使用して新しい要素を作成します。接頭辞付きのcreateElementNSの違いは何ですか? XHTMLページにリンクされているJSで

const NS = 'http://my.site/xmlns'; 
const el1 = document.createElementNS(NS, 'custom'); 
const el2 = document.createElementNS(NS, 'p:custom'); 

私は2番目の引数に名前空間接頭辞を使用して作成要素とせずに作成したものとの違いが何であるかを理解することはできませんそれ。例えば、これらのCSSルールは両方要素で同じ効果があります。

@namespace p url('http://my.site/xmlns'); 
p|custom { background: yellow; } 

次のdocument.getElementsByTagNameNS(NS, 'p:custom')が私には奇妙に思える、空HtmlCollectionを返すのに対し、document.getElementsByTagNameNS(NS, 'custom')の呼び出しは、HtmlCollectionとの両方の要素を返します。

だから、名前空間接頭辞付きの要素とそれを持たない要素の作成の違いは何ですか?

答えて

1

document.createElementNS()は、2番目のパラメータが修飾タグ名であると想定しています。 p:customは修飾タグ名なので、document.createElementNS(NS, 'p:custom')がより正確です。私はその理由を疑っているdocument.createElementNS(NS, 'custom')の作品は、遺産の理由によるものです。一方、第2のパラメータがローカルタグ名であることを期待する。 customはローカルタグ名です。 (customが名前空間を持っていない場合、それはまた、その修飾名です。)

あなたの要素が名前空間、およびその修飾名がp:customでいるので、自分のローカル名がcustomで、p:customではないので、そうdocument.getElementsByTagNameNS(NS, 'p:custom')は何も返しませんそのローカル名。

+0

最初の引数で指定された名前空間がドキュメント内の名前空間接頭辞で宣言されている場合、修飾名(QName)は 'createElementNS()'の名前空間接頭辞で修飾する必要はありません。 https://developer.mozilla.org/en-US/docs/Web/API/Document/createElementNS –

+0

@Scott Marcus:ああ、どうしたの?仕様もMDNもこれを明示的に示していないので、私が紛失しているものがなければなりません。 – BoltClock

+0

ええ、聞いたことがありますが、MDNページでは、表現されたQNameなしで使用されていることが示されていますが、ドキュメント内に同じ名前空間が既に宣言されています(接頭辞付き)。あなたが指定する新しい要素が暗黙的に正しいQNameを持つという接頭語で既に宣言されています。 –

関連する問題