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 属性可以更方便地添加、删除或切换类名。

相关推荐
We་ct12 分钟前
LeetCode 97. 交错字符串:动态规划详解
前端·算法·leetcode·typescript·动态规划
Chengbei1121 分钟前
轻量化 Web 安全日志分析神器 星川智盾日志威胁检测、地理溯源、MITRE ATT&CK 映射,支持 Windows/macOS/Linux
前端·人工智能·安全·web安全·macos·系统安全·安全架构
风流 少年23 分钟前
Python Web框架:FastAPI
前端·python·fastapi
GISer_Jing31 分钟前
AI时代面试新常态——从“会用工具”到“深挖原理”的跨越
前端·人工智能·ai编程
IT_陈寒41 分钟前
React的useEffect把我坑惨了,这些闭包陷阱真要命
前端·人工智能·后端
前端之虎陈随易1 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·typescript·npm·node.js
ayqy贾杰1 小时前
Cursor SDK发布!开发者可直接搬走其内核
前端·vue.js·面试
椰猫子1 小时前
SpringMVC(SpringMVC简介、请求与响应(请求映射路径、请求参数、日期类型参数传递、响应json数据))
java·前端·数据库
love530love1 小时前
如何在 Google Chrome 中强制开启 Gemini AI 侧边栏(完整图文教程)
前端·人工智能·chrome·windows
光影少年1 小时前
对typescript开发框架的理解?
前端·javascript·typescript