HTML DOM - 修改 HTML 内容的方法

修改 HTML 内容的方法

通过 JavaScript 操作 DOM(文档对象模型)可以动态修改 HTML 内容。以下是几种常见的方法:

innerHTML 属性 使用 innerHTML 属性可以获取或设置元素的 HTML 内容。这种方法会解析字符串中的 HTML 标签。

javascript 复制代码
document.getElementById("demo").innerHTML = "<strong>新内容</strong>";

textContent 属性 textContent 属性用于获取或设置元素的文本内容,不会解析 HTML 标签。

javascript 复制代码
document.getElementById("demo").textContent = "纯文本内容";

innerText 属性 innerText 属性与 textContent 类似,但会忽略隐藏元素的内容。

javascript 复制代码
document.getElementById("demo").innerText = "可见文本内容";

修改 HTML 属性

除了内容,还可以通过 DOM 修改 HTML 元素的属性。

setAttribute 方法 使用 setAttribute 方法可以设置元素的属性值。

javascript 复制代码
document.getElementById("myImage").setAttribute("src", "new-image.jpg");

直接修改属性 某些属性可以直接通过元素对象修改。

javascript 复制代码
document.getElementById("myImage").src = "new-image.jpg";

创建和插入新元素

可以通过 DOM 动态创建新元素并插入到文档中。

createElement 方法 使用 createElement 方法创建新元素。

javascript 复制代码
var newElement = document.createElement("div");
newElement.innerHTML = "新创建的 div";

appendChild 方法 使用 appendChild 方法将新元素添加到父元素的末尾。

javascript 复制代码
document.body.appendChild(newElement);

insertBefore 方法 使用 insertBefore 方法将新元素插入到指定元素之前。

javascript 复制代码
var parent = document.getElementById("parent");
var referenceElement = document.getElementById("reference");
parent.insertBefore(newElement, referenceElement);

删除和替换元素

可以通过 DOM 删除或替换现有元素。

removeChild 方法 使用 removeChild 方法从父元素中删除子元素。

javascript 复制代码
var parent = document.getElementById("parent");
var child = document.getElementById("child");
parent.removeChild(child);

replaceChild 方法 使用 replaceChild 方法替换子元素。

javascript 复制代码
var parent = document.getElementById("parent");
var oldChild = document.getElementById("oldChild");
var newChild = document.createElement("div");
newChild.innerHTML = "新内容";
parent.replaceChild(newChild, oldChild);

修改 CSS 样式

通过 DOM 可以动态修改元素的 CSS 样式。

style 属性 使用 style 属性直接修改元素的样式。

javascript 复制代码
document.getElementById("demo").style.color = "red";
document.getElementById("demo").style.fontSize = "20px";

className 属性 使用 className 属性修改元素的类名。

javascript 复制代码
document.getElementById("demo").className = "new-class";

classList 属性 使用 classList 属性可以更方便地添加、删除或切换类名。

相关推荐
wordbaby29 分钟前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩31 分钟前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思2 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫3 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。4 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星4 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒5 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩5 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi5 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具
哆来A梦没有口袋5 小时前
干货精讲 | 初级CSS面试高频考题
前端·css·面试