Attr.namespaceURI

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

Attr.namespaceURI 只读属性返回属性的命名空间 URI,如果该元素不在命名空间中,则返回 null。

备注: 在 DOM4 之前,该 API 是在 Node 中定义的。

示例

在这个片段中,正在检查一个属性的 localNamenamespaceURI。如果 namespaceURI 返回 XUL 命名空间,并且 localName 返回 "browser",则该节点被理解为 XUL <browser/>

js
if (
  attribute.localName == "value" &&
  attribute.namespaceURI ==
    "http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul"
) {
  // this is a XUL value
}

笔记

这不是基于对范围中的命名空间声明的检查的命名空间查找的结果的计算值。 属性的命名空间 URI 在属性创建时被冻结。

在 Firefox 3.5 及更早版本中,HTML 文档中 HTML 属性的命名空间 URI 为 null。 在后来的版本中,遵照 HTML5,就像在 XHTML 中一样是https://www.w3.org/1999/xhtml

你可以使用 DOM Level 2 方法 Element.setAttributeNS创建具有指定 namespaceURI 的属性。

根据 Namespaces in XML 规范,属性不会从其附加的元素继承其命名空间。 如果一个属性没有明确地给出一个命名空间,它没有命名空间。

DOM 本身不处理或强制命名空间验证。DOM 应用程序需要做任何必要的验证。 还要注意,一旦与特定节点相关联,命名空间前缀将无法更改。

规格

Specification
DOM
# dom-attr-namespaceuri

浏览器兼容性

Report problems with this compatibility data on GitHub
desktopmobile
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
namespaceURI

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support

其他文章