DOM节点类型列举

DOM节点类型列举

在 JavaScript 中,DOM(Document Object Model)节点是 HTML 或 XML 文档的基本构建块。每个节点都有一个 nodeType 属性,用于标识节点的类型。以下是常见的 DOM 节点类型及其对应的 nodeType 值:

  1. 元素节点 (Element)
  • nodeType : 1

  • 描述 : 表示 HTML 或 XML 文档中的元素(标签),如 <div><p><a> 等。

  • 示例:

    html 复制代码
    <div id="example">Hello, World!</div>
    javascript 复制代码
    const element = document.getElementById("example");
    console.log(element.nodeType); // 输出: 1
  1. 属性节点 (Attr)
  • nodeType : 2

  • 描述 : 表示元素的属性,如 idclasshref 等。

  • 示例:

    html 复制代码
    <a href="https://example.com">Link</a>
    javascript 复制代码
    const link = document.querySelector("a");
    const attr = link.getAttributeNode("href");
    console.log(attr.nodeType); // 输出: 2
  1. 文本节点 (Text)
  • nodeType : 3

  • 描述: 表示元素或属性中的文本内容。

  • 示例:

    html 复制代码
    <p>Hello, World!</p>
    javascript 复制代码
    const paragraph = document.querySelector("p");
    const textNode = paragraph.childNodes[0]; // 获取文本节点
    console.log(textNode.nodeType); // 输出: 3
  1. 注释节点 (Comment)
  • nodeType : 8

  • 描述: 表示 HTML 或 XML 文档中的注释。

  • 示例:

    html 复制代码
    <!-- This is a comment -->
    javascript 复制代码
    const comment = document.body.childNodes[0]; // 假设注释是第一个子节点
    console.log(comment.nodeType); // 输出: 8
  1. 文档节点 (Document)
  • nodeType : 9

  • 描述: 表示整个文档(根节点)。

  • 示例 :

    javascript 复制代码
    console.log(document.nodeType); // 输出: 9
  1. 文档类型节点 (DocumentType)
  • nodeType : 10

  • 描述 : 表示文档类型声明(如 <!DOCTYPE html>)。

  • 示例:

    html 复制代码
    <!DOCTYPE html>
    javascript 复制代码
    const doctype = document.doctype;
    console.log(doctype.nodeType); // 输出: 10
  1. 文档片段节点 (DocumentFragment)
  • nodeType : 11

  • 描述: 表示一个轻量级的文档片段,用于高效地操作和插入多个节点。

  • 示例 :

    javascript 复制代码
    const fragment = document.createDocumentFragment();
    console.log(fragment.nodeType); // 输出: 11
  1. CDATA 节点 (CDATASection)
  • nodeType : 4

  • 描述: 表示 XML 文档中的 CDATA 部分(不解析的文本数据)。

  • 示例 :

    xml 复制代码
    <![CDATA[<message>Hello, World!</message>]]>
  1. 实体引用节点 (EntityReference)
  • nodeType : 5
  • 描述 : 表示 XML 文档中的实体引用(如 &amp;)。
  • 注意: 在 HTML 中不常用。
  1. 实体节点 (Entity)
  • nodeType : 6
  • 描述: 表示 XML 文档中的实体定义。
  • 注意: 在 HTML 中不常用。
  1. 处理指令节点 (ProcessingInstruction)
  • nodeType : 7
  • 描述 : 表示 XML 文档中的处理指令(如 <?xml-stylesheet ...?>)。
  • 注意: 在 HTML 中不常用。

总结

以下是常见的 DOM 节点类型及其 nodeType 值:

nodeType 节点类型 描述
1 元素节点 (Element) HTML 或 XML 元素
2 属性节点 (Attr) 元素的属性
3 文本节点 (Text) 元素或属性中的文本内容
4 CDATA 节点 (CDATASection) XML 中的 CDATA 部分
5 实体引用节点 (EntityReference) XML 中的实体引用
6 实体节点 (Entity) XML 中的实体定义
7 处理指令节点 (ProcessingInstruction) XML 处理指令
8 注释节点 (Comment) HTML 或 XML 注释
9 文档节点 (Document) 整个文档
10 文档类型节点 (DocumentType) 文档类型声明
11 文档片段节点 (DocumentFragment) 轻量级文档片段

在实际开发中,最常用的是元素节点 (1)、文本节点 (3) 和注释节点 (8)。通过 nodeType 可以快速判断节点的类型,从而进行相应的操作。

更多vue相关插件及后台管理模板可访问vue admin reference,代码详情请访问github

相关推荐
Nan_Shu_614几秒前
学习:入门uniapp Vue3组合式API版本(17)
前端·vue.js·学习·uni-app
止观止31 分钟前
Remix框架:高性能React全栈开发实战
前端·react.js·前端框架·remix
萌萌哒草头将军1 小时前
🚀🚀🚀 深入探索 Node.js v22.18.0 新特性;默认支持运行 ts 文件了!
前端·typescript·node.js
安心不心安1 小时前
React ahooks——副作用类hooks之useThrottleFn
前端·javascript·react.js
秋田君1 小时前
Vue3 + WebSocket网页接入弹窗客服功能的完整实现
前端·javascript·websocket·网络协议·学习
浪里行舟1 小时前
一网打尽 Promise 组合技:race vs any, all vs allSettled,再也不迷糊!
前端·javascript·vue.js
Antonio9152 小时前
【网络编程】WebSocket 实现简易Web多人聊天室
前端·网络·c++·websocket
德育处主任Pro3 小时前
p5.js 用 beginGeometry () 和 endGeometry () 打造自定义 3D 模型
开发语言·javascript·3d
tianzhiyi1989sq3 小时前
Vue3 Composition API
前端·javascript·vue.js
今禾3 小时前
Zustand状态管理(上):现代React应用的轻量级状态解决方案
前端·react.js·前端框架