JavaScript HTML DOM 元素 (节点)

简介: JavaScript HTML DOM 元素 (节点)

本章节介绍如何向文档中添加和移除元素(节点)。


创建新的 HTML 元素 (节点) - appendChild()

要创建新的 HTML 元素 (节点)需要先创建一个元素,然后在已存在的元素中添加它。

实例

<div id="div1"><p id="p1">这是一个段落。</p><p id="p2">这是另外一个段落。</p></div> <script>var para = document.createElement("p"); var node = document.createTextNode("这是一个新的段落。"); para.appendChild(node);   var element = document.getElementById("div1"); element.appendChild(para);</script>


尝试一下 »


实例解析

以下代码是用于创建 <p> 元素:

var para = document.createElement("p");

为 <p> 元素创建一个新的文本节点:

var node = document.createTextNode("这是一个新的段落。");

将文本节点添加到 <p> 元素中:

para.appendChild(node);

最后,在一个已存在的元素中添加 p 元素。

查找已存在的元素:

var element = document.getElementById("div1");

添加到已存在的元素中:

element.appendChild(para);


创建新的 HTML 元素 (节点) - insertBefore()

以上的实例我们使用了 appendChild() 方法,它用于添加新元素到尾部。

如果我们需要将新元素添加到开始位置,可以使用 insertBefore() 方法:

实例

<div id="div1"><p id="p1">这是一个段落。</p><p id="p2">这是另外一个段落。</p></div> <script>var para = document.createElement("p"); var node = document.createTextNode("这是一个新的段落。"); para.appendChild(node);   var element = document.getElementById("div1"); var child = document.getElementById("p1"); element.insertBefore(para, child);</script>


尝试一下 »


移除已存在的元素

要移除一个元素,你需要知道该元素的父元素。

实例

<div id="div1"><p id="p1">这是一个段落。</p><p id="p2">这是另外一个段落。</p></div> <script>var parent = document.getElementById("div1"); var child = document.getElementById("p1"); parent.removeChild(child);</script>


尝试一下 »

注意:早期的 Internet Explorer 浏览器不支持 node.remove() 方法。

实例解析

HTML 文档中 <div> 元素包含两个子节点 (两个 <p> 元素):

<div id="div1">

<p id="p1">这是一个段落。</p>

<p id="p2">这是另外一个段落。</p>

</div>

查找 id="div1" 的元素:

var parent = document.getElementById("div1");

查找 id="p1" 的 <p> 元素:

var child = document.getElementById("p1");

从父元素中移除子节点:

parent.removeChild(child);

如果能够在不引用父元素的情况下删除某个元素,就太好了。
不过很遗憾。DOM 需要清楚您需要删除的元素,以及它的父元素。

以下代码是已知要查找的子元素,然后查找其父元素,再删除这个子元素(删除节点必须知道父节点):

var child = document.getElementById("p1");

child.parentNode.removeChild(child);


替换 HTML 元素 - replaceChild()

我们可以使用 replaceChild() 方法来替换 HTML DOM 中的元素。

实例

<div id="div1"><p id="p1">这是一个段落。</p><p id="p2">这是另外一个段落。</p></div> <script>var para = document.createElement("p"); var node = document.createTextNode("这是一个新的段落。"); para.appendChild(node);   var parent = document.getElementById("div1"); var child = document.getElementById("p1"); parent.replaceChild(para, child);</script>


尝试一下 »


HTML DOM 教程

在我们的 JavaScript 教程的 HTML DOM 部分,您已经学到了:

  • 如何改变 HTML 元素的内容 (innerHTML)
  • 如何改变 HTML 元素的样式 (CSS)
  • 如何对 HTML DOM 事件作出反应
  • 如何添加或删除 HTML 元素

如果您希望学到更多有关使用 JavaScript 访问 HTML DOM 的知识,请访问我们完整的 HTML DOM 教程

目录
相关文章
|
5月前
|
XML 前端开发 C#
C#编程实践:解析HTML文档并执行元素匹配
通过上述步骤,可以在C#中有效地解析HTML文档并执行元素匹配。HtmlAgilityPack提供了一个强大而灵活的工具集,可以处理各种HTML解析任务。
287 19
|
8月前
|
移动开发 前端开发 JavaScript
HTML表单验证:确认input元素输入为具有特定整数和小数位数的数值。
将上述JavaScript代码与HTML一同使用,便可以确保用户输入的数值符合特定的格式要求。特别要注意,在实际的生产环境中,仅仅依靠前端验证是不够的。为了安全起见,后端也应该实施相应的验证措施,以防止不匹配格式的数据通过其他手段提交到服务器。
452 74
|
9月前
|
缓存 JavaScript 前端开发
Vue 项目中动态添加 HTML 元素的方法与实践
本文探讨了 Vue 中动态添加 HTML 元素的多种技术方案,包括条件渲染(v-if/v-show)、动态组件(component :is)、手动挂载($mount)及 Vuex 状态管理等方法。通过实例分析,如动态表单生成器与全局模态框服务,展示了这些方案在实际开发中的应用。同时提供了性能优化建议和注意事项,帮助开发者根据需求选择最佳方式,在保持 Vue 响应式特性的同时实现灵活交互。附带代码示例,便于理解和实践。
270 2
|
JavaScript 前端开发
JavaScript HTML DOM
JavaScript HTML DOM
139 2
JavaScript HTML DOM
|
JavaScript 前端开发 索引
JavaScript HTML DOM 节点列表
JavaScript HTML DOM 节点列表
153 5
|
JavaScript 前端开发
JavaScript HTML DOM 事件
JavaScript HTML DOM 事件
133 5
|
JavaScript 前端开发
JavaScript HTML DOM - 改变CSS
JavaScript HTML DOM - 改变CSS
112 5
|
JavaScript 前端开发 索引
JavaScript HTML DOM 集合(Collection)
JavaScript HTML DOM 集合(Collection)
164 4
|
JavaScript 前端开发
JavaScript HTML DOM EventListener
JavaScript HTML DOM EventListener
166 2

热门文章

最新文章