新闻中心
使用 J*aScript 函数动态添加 CSS 样式:最佳实践指南

本文旨在指导开发者如何使用 J*aScript 函数动态地向 HTML 元素添加 CSS 样式,避免使用 `document.write()`,并采用 `appendChild` 和 `classList.add` 等更现代、更安全的方法。通过示例代码和详细解释,帮助读者理解如何在 J*aScript 中高效地操作 CSS 样式,从而实现更灵活和可维护的前端代码。
避免使用 document.write()
document.write() 方法在现代 Web 开发中已不推荐使用。它可能会导致页面加载性能问题,并且在某些情况下会覆盖现有的 HTML 结构,导致不可预测的行为。因此,我们应该寻找替代方案。
使用 appendChild 创建和添加元素
appendChild 方法允许我们动态地创建 HTML 元素,并将其添加到 DOM 树中。这是一种更安全、更灵活的方式来构建页面内容。
例如,要创建一个
元素并将其添加到 qr-container div 中,可以这样做:function openQRCodeWindow(registrationId) {
const container = document.querySelector('.qr-container');
const titleElement = document.createElement('h1');
titleElement.textContent = 'ABC';
container.appendChild(titleElement);
}
openQRCodeWindow('');
这段代码首先使用 document.querySelector 找到 class 为 qr-container 的元素。然后,它创建一个新的
元素,设置其文本内容为 "ABC",并使用 appendChild 将其添加到 qr-container 中。使用 classList.add 添加 CSS 类
为了应用 CSS 样式,我们可以使用 classList.add 方法向元素添加 CSS 类。这使得我们可以将样式定义与 J*aScript 代码分离,从而提高代码的可维护性。
例如,要向上面创建的
AI Surge Cloud
低代码数据分析平台,帮助企业快速交付深度数据
87
查看详情
元素添加一个名为 title 的 CSS 类,可以这样做:function openQRCodeWindow(registrationId) {
const container = document.querySelector('.qr-container');
const titleElement = document.createElement('h1');
titleElement.textContent = 'ABC';
titleElement.classList.add('title');
container.appendChild(titleElement);
}
openQRCodeWindow('');
然后,在你的 CSS 文件中,你可以定义 .title 类的样式:
.title {
color: red;
}这样,
元素的文本颜色就会变成红色。完整示例
将上述概念整合,我们可以创建一个更完整的示例,动态地创建包含样式的 QR 码信息:
<!DOCTYPE html>
<html>
<head>
<title>Dynamic QR Code</title>
<style>
.container {
display: flex;
justify-content: space-between;
align-items: center;
padding: 50px;
border: 2px solid #ccc;
border-radius: 10px;
width: 400px;
}
.qr-container {
margin-right: 20px;
}
.details-container {
text-align: right;
}
.title {
color: blue;
font-size: 24px;
}
</style>
</head>
<body>
<div class="container" id="form-container">
<div class="qr-container">
<!-- QR code image will be added here -->
</div>
<div class="details-container">
<!-- Details will be added here -->
</div>
</div>
<script>
function openQRCodeWindow(registrationId, firstName, lastName, email, contactNumber, seatNumber, qrCodeImage) {
const qrContainer = document.
querySelector('.qr-container');
const detailsContainer = document.querySelector('.details-container');
// Create and append QR code image
const qrImage = document.createElement('img');
qrImage.src = qrCodeImage;
qrContainer.appendChild(qrImage);
// Create and append details
const titleElement = document.createElement('h3');
titleElement.textContent = 'Details';
detailsContainer.appendChild(titleElement);
const registrationIdElement = document.createElement('p');
registrationIdElement.textContent = 'Registration ID: ' + registrationId;
detailsContainer.appendChild(registrationIdElement);
const firstNameElement = document.createElement('p');
firstNameElement.textContent = 'First Name: ' + firstName;
detailsContainer.appendChild(firstNameElement);
const lastNameElement = document.createElement('p');
lastNameElement.textContent = 'Last Name: ' + lastName;
detailsContainer.appendChild(lastNameElement);
const emailElement = document.createElement('p');
emailElement.textContent = 'Email: ' + email;
detailsContainer.appendChild(emailElement);
const contactNumberElement = document.createElement('p');
contactNumberElement.textContent = 'Contact Number: ' + contactNumber;
detailsContainer.appendChild(contactNumberElement);
const seatNumberElement = document.createElement('p');
seatNumberElement.textContent = seatNumber;
detailsContainer.appendChild(seatNumberElement);
}
// Example usage (replace with your actual data)
const qrCodeDataURL = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w+bL/DAAMRQw0YmrNw4nNLAYXjv0gAAAAABJRU5ErkJggg=="; // Replace with your actual QR code data URL
openQRCodeWindow('12345', 'John', 'Doe', 'john.doe@example.com', '123-456-7890', 'Seat A1', qrCodeDataURL);
</script>
</body>
</html>代码解释:
- HTML 结构: 创建了包含 qr-container 和 details-container 的基本 HTML 结构。
- CSS 样式: 定义了 container,qr-container,details-container 和 title 类的样式,以控制布局和外观。
-
openQRCodeWindow 函数:
- 接收 QR 码数据和其他详细信息作为参数。
- 使用 document.querySelector 获取 qr-container 和 details-container 元素。
- 使用 document.createElement 创建 HTML 元素(img, h3, p)。
- 设置元素的 src 或 textContent 属性。
- 使用 appendChild 将新元素添加到相应的容器中。
- 示例用法: 调用 openQRCodeWindow 函数,并传递示例数据(需要替换为实际数据)。 请注意,qrCodeDataURL 需要替换为实际的 QR 码 data URL。
总结
通过使用 appendChild 和 classList.add 等方法,我们可以更安全、更灵活地在 J*aScript 中动态地操作 CSS 样式。 这种方法避免了使用 document.write() 带来的问题,并使我们的代码更易于维护和扩展。 记住将样式定义与 J*aScript 代码分离,以获得更好的代码组织和可读性。
以上就是使用 J*aScript 函数动态添加 CSS 样式:最佳实践指南的详细内容,更多请关注其它相关文章!
# 这样做
# 闪电seo是什么软件
# 奉化商家推广招聘网站
# seo好还是竞价好
# 厦门网站建设应该找哪家
# 营销网站建设流程表
# 永康网站建设小程序
# 长江工程建设局网站
# 福田网站推广及营销方案
# 苏州网站建设软件推广
# 深圳哪里可以做网站优化
# 你可以
# 就会
# 容器内
# 拖拽
# 自定义
# css
# 更灵活
# 创建一个
# 复选框
# 我们可以
# red
# win
# ai
# ssl
# app
# go
# 前端
# html
# java
# javascript
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
零跑汽车11月交付量达70327台 实现连续9个月正增长
Win10双系统截图高效法 截屏快捷键速记【技巧】
如何在J*a中使用Locale处理多语言环境
c++项目目录结构应该如何组织_c++工程化项目结构规范
理解Python模块与全局变量的作用域管理
TikTok国际版网页端快速入口 TikTok全球版短视频浏览教程
在J*a中如何使用BigDecimal进行高精度计算_BigDecimal类应用指南
QQ邮箱网页版入口登录 QQ邮箱在线邮箱官方通道
C++指针和引用有什么区别_C++内存管理核心概念深度解析
LINUX的perf命令入门_LINUX官方性能分析工具的使用与解读
支付宝解绑银行卡步骤_支付宝如何解除绑定银行卡
一加手机拍照效果不好怎么办 一加哈苏影像调校与专业模式使用教程【高手篇】
在Go开发中优雅管理ListenAndServe进程:GoSublime集成方案
cad怎么合并重叠的线段_cad清理重复重叠线条的操作方法
没有大陆身份证/银行卡如何实名微信? 亲测有效的几种方法分享
J*aScript数组对象转换:按指定键分组与值收集
C++如何实现一个装饰器模式_C++设计模式之动态地给对象添加额外职责
蛙漫安全无毒 官方认证的绿色入口
荣耀Play7TPro怎样在信息App置顶客服对话_iPhone荣耀Play7TPro信息App置顶客服对话【优先查看】
微信网页版扫码登录入口 微信网页版二维码登录入口
汽水音乐网页版使用入口_汽水音乐电脑版播放指南
J*aScript中安全有效地处理localStorage字符串数据
J*aScript实现动态背景色下的文本与按钮颜色自适应调整
如何将HTML表格多行数据保存到Google Sheets
Win11怎么查看显卡显存 Win11显示适配器属性及专用视频内存查询
Composer的 "licenses" 命令如何帮助你遵守开源协议_检查项目依赖的许可证合规性
QQ邮箱官方网页版登录 QQ邮箱个人邮箱快速访问
在VS Code中配置和运行Dart程序的完整步骤
C++ map遍历方法大全_C++ map迭代器使用总结
AI抖音网页版免费视频入口 AI抖音网页端最新视频实时观看
《北京人工智能产业白皮书(2025)》发布:全年核心产值预计突破 4500 亿元
将HTML动态表格多行数据保存到Google Sheet的教程
c++如何实现单例设计模式_c++线程安全的单例模式写法
AO3网页版合集入口 Archive of Our Own同人作品浏览指南
C++ string find函数返回值npos详解_C++字符串查找失败的判断条件
Lar*el用户头像管理:实现图片缩放、存储与旧文件安全删除的最佳实践
《刺客信条4:黑旗》重制版新细节曝光:无缝加载 地图更细致!
HTML5原生日期选择器与jQuery UI:实现日期选择器的联动与程序化控制
NVIDIA股价11月重挫12%:下月有望好转 但难回5万亿美元巅峰
如何在离线环境中使用Composer_Composer离线安装依赖包的技巧与策略
高德地图总提示网络异常怎么办 高德地图离线导航设置与网络排查方法
J*a递归快速排序中静态变量导致数据累积的陷阱与解决方案
晋江读书网页版在线登录 晋江读书电脑版官网
抖音网页版怎么|直播|_抖音网页版开播操作指南
J*a递归快速排序中静态变量导致数据累积问题的解决方案
蛙漫官网漫画入口地址_蛙漫在线畅读无广告弹窗
Centos/Linux 系统下安装 composer 的完整步骤
在J*a项目里如何构建对象之间的契约_接口约束的实际落地
windows10怎么查看本机ip_windows10命令提示符ipconfig使用
Composer如何在生产环境安全地执行composer update


2025-10-19
浏览次数:次
返回列表
querySelector('.qr-container');
const detailsContainer = document.querySelector('.details-container');
// Create and append QR code image
const qrImage = document.createElement('img');
qrImage.src = qrCodeImage;
qrContainer.appendChild(qrImage);
// Create and append details
const titleElement = document.createElement('h3');
titleElement.textContent = 'Details';
detailsContainer.appendChild(titleElement);
const registrationIdElement = document.createElement('p');
registrationIdElement.textContent = 'Registration ID: ' + registrationId;
detailsContainer.appendChild(registrationIdElement);
const firstNameElement = document.createElement('p');
firstNameElement.textContent = 'First Name: ' + firstName;
detailsContainer.appendChild(firstNameElement);
const lastNameElement = document.createElement('p');
lastNameElement.textContent = 'Last Name: ' + lastName;
detailsContainer.appendChild(lastNameElement);
const emailElement = document.createElement('p');
emailElement.textContent = 'Email: ' + email;
detailsContainer.appendChild(emailElement);
const contactNumberElement = document.createElement('p');
contactNumberElement.textContent = 'Contact Number: ' + contactNumber;
detailsContainer.appendChild(contactNumberElement);
const seatNumberElement = document.createElement('p');
seatNumberElement.textContent = seatNumber;
detailsContainer.appendChild(seatNumberElement);
}
// Example usage (replace with your actual data)
const qrCodeDataURL = "data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAUAAAAFCAYAAACNbyblAAAAHElEQVQI12P4//8/w+bL/DAAMRQw0YmrNw4nNLAYXjv0gAAAAABJRU5ErkJggg=="; // Replace with your actual QR code data URL
openQRCodeWindow('12345', 'John', 'Doe', 'john.doe@example.com', '123-456-7890', 'Seat A1', qrCodeDataURL);
</script>
</body>
</html>