Bootstrap

如何修改 DOM 结构

前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站

简介

在“理解 DOM 系列”的前两篇文章中,我们学习了如何访问 DOM 中的元素以及如何遍历 DOM。利用这些知识,开发人员可以使用类、标签、ID 和选择器来查找 DOM 中的任何节点,并使用父节点、子节点和兄弟节点属性来查找相关节点。

成为 DOM 更全面的熟练使用者的下一步是学习如何添加、更改、替换和移除节点。一个实际的例子是一个 JavaScript 程序中的待办事项列表应用,其中您需要能够在 DOM 中创建、修改和移除元素。

在本教程中,我们将介绍如何创建新节点并将它们插入到 DOM 中,替换现有节点以及移除节点。

创建新节点

在静态网站中,通过直接在 .html 文件中编写 HTML 来向页面添加元素。在动态 Web 应用中,通常使用 JavaScript 来添加元素和文本。createElement()createTextNode() 方法用于在 DOM 中创建新节点。

属性/方法描述
createElement()创建新的元素节点
createTextNode()创建新的文本节点
node.textContent获取或设置元素节点的文本内容
node.innerHTML获取或设置元素的 HTML 内容

首先,让我们创建一个 index.html 文件并将其保存在一个新的项目目录中。


<!DOCTYPE html>
<html lang="en">

  <head>
    <title>学习 DOM</title>
  </head>

  <body>
    <h1>文档对象模型</h1>
  </body>

</html>

在页面的任意位置右键单击,然后选择“检查”以打开开发者工具,然后导航到控制台

我们将在 document 对象上使用 createElement() 来创建一个新的 p 元素。

const paragraph = document.createElement('p');

我们已经创建了一个新的 p 元素,在 控制台 中可以测试它。

console.log(paragraph)

<p></p>

paragraph 变量输出了一个空的 p 元素,没有任何文本内容,这样并不是很有用。为了向元素添加文本,我们将设置 textContent 属性。

paragraph.textContent = "我是一个全新的段

## 从 DOM 中移除节点

现在我们知道如何创建元素,将它们添加到 DOM 中,并修改现有元素。最后一步是学习如何从 DOM 中移除现有节点。可以使用 `removeChild()` 从父节点中移除子节点,也可以使用 `remove()` 来移除节点本身。

| 方法                      | 描述             |
| -------------------------- | ----------------- |
| `node.removeChild()`       | 移除子节点       |
| `node.remove()`            | 移除节点         |

使用上面的待办事项示例,我们将希望在完成后删除项目。如果你完成了家庭作业,可以使用 `removeChild()` 来移除列表中的最后一个子节点 `Do homework`。

```custom_prefix(>)
todoList.removeChild(todoList.lastElementChild);

<ul>
  <li>Pay bills</li>
  <li>Buy groceries</li>
  <li>Feed the dog</li>
  <li>Do laundry</li>
</ul>

!DOM Screenshot 5

另一种方法是直接使用 remove() 方法从 DOM 中移除节点本身。

// 从 todoList 中直接移除第二个子节点
todoList.children[1].remove();

<ul>
  <li>Pay bills</li>
  <li>Feed the dog</li>
  <li>Do laundry</li>
</ul>

!DOM Screenshot 6

removeChild()remove() 之间,你可以从 DOM 中移除任何节点。另一种你可能会看到的移除子元素的方法是将父元素的 innerHTML 属性设置为空字符串 ("")。这不是首选方法,因为它不够明确,但你可能会在现有代码中看到它。

结论

在本教程中,我们学习了如何使用 JavaScript 创建新节点和元素,并将它们插入到 DOM 中,以及替换和移除现有节点和元素。

通过《理解 DOM 系列》到这一步,你已经知道如何访问 DOM 中的任何元素,遍历 DOM 中的任何节点,并修改 DOM 本身。现在你可以自信地使用 JavaScript 创建基本的前端 Web 应用程序了。

;