使用 JavaScript 函数动态添加 CSS 样式:最佳实践指南

使用 javascript 函数动态添加 css 样式:最佳实践指南

本文旨在指导开发者如何使用 JavaScript 函数动态地向 HTML 元素添加 CSS 样式,避免使用 `document.write()`,并采用 `appendChild` 和 `classList.add` 等更现代、更安全的方法。通过示例代码和详细解释,帮助读者理解如何在 JavaScript 中高效地操作 CSS 样式,从而实现更灵活和可维护的前端代码。

避免使用 document.write()

document.write() 方法在现代 Web 开发中已不推荐使用。它可能会导致页面加载性能问题,并且在某些情况下会覆盖现有的 HTML 结构,导致不可预测的行为。因此,我们应该寻找替代方案。

使用 appendChild 创建和添加元素

appendChild 方法允许我们动态地创建 HTML 元素,并将其添加到 DOM 树中。这是一种更安全、更灵活的方式来构建页面内容。

例如,要创建一个

元素并将其添加到 qr-container div 中,可以这样做:

立即学习“Java免费学习笔记(深入)”;

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 类。这使得我们可以将样式定义与 JavaScript 代码分离,从而提高代码的可维护性。

vizcom.ai vizcom.ai

AI草图渲染工具,快速将手绘草图渲染成精美的图像

vizcom.ai 70 查看详情 vizcom.ai

例如,要向上面创建的

元素添加一个名为 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 码信息:

  Dynamic QR Code      .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;    }    
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);

代码解释:

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 等方法,我们可以更安全、更灵活地在 JavaScript 中动态地操作 CSS 样式。 这种方法避免了使用 document.write() 带来的问题,并使我们的代码更易于维护和扩展。 记住将样式定义与 JavaScript 代码分离,以获得更好的代码组织和可读性。

以上就是使用 JavaScript 函数动态添加 CSS 样式:最佳实践指南的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/725758.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月24日 17:36:05
下一篇 2025年11月24日 17:37:11

相关推荐

  • 币安与火币HTX深度评测_手续费安全性全解析最新版

    币安 1. 币安是全球用户量和交易量领先的加密货币交易所之一,提供广泛的数字资产交易服务。 2. 平台支持现货交易、合约交易(包括永续合约和交割合约)、期权交易等多种交易产品。 3. 币安拥有庞大的用户基础和极高的市场流动性,用户可以在其平台上交易多种主流及新兴加密货币。 4. 平台构建了一个包含B…

    2025年12月8日
    000
  • 数字货币交易平台前十名最新榜单

    数字货币市场的活力日益增强,为全球投资者提供了丰富的交易机会。在这个充满活力的领域,选择一个可靠、安全且功能全面的交易平台至关重要。这些平台是连接用户与数字资产世界的桥梁,其提供的服务水平、安全性以及支持的资产种类直接影响着用户的交易体验和资产安全。本榜单旨在呈现当前市场上表现突出的一些数字货币交易…

    2025年12月8日 好文分享
    000
  • 十大加密货币交易平台

    数字货币市场的活力日益增强,为全球投资者提供了丰富的交易机会。在这个充满活力的领域,选择一个可靠、安全且功能全面的交易平台至关重要。这些平台是连接用户与数字资产世界的桥梁,其提供的服务水平、安全性以及支持的资产种类直接影响着用户的交易体验和资产安全。本榜单旨在呈现当前市场上表现突出的一些数字货币交易…

    2025年12月8日 好文分享
    000
  • 欧意跟Bianca交易所有什么不同

    欧意(okx)与币安(binance)作为加密货币交易领域的两大巨头,为全球数以千万计的用户提供服务。它们在功能上存在诸多相似之处,都提供现货、合约等主流交易服务。然而,在深层战略、产品侧重、生态构建以及用户体验等多个维度上,两者展现出鲜明的差异化路径。理解这些不同之处,有助于用户根据自身的需求和偏…

    2025年12月8日 好文分享
    000
  • okx跟火币网相比有什么不同

    okx与火币网(现已更名为htx)作为全球知名的加密资产交易平台,为广大用户提供了丰富的数字资产交易与管理服务。它们在品牌历史、产品侧重、用户体验及生态布局上存在着显著的差异。理解这些不同之处,有助于用户根据自身的需求和偏好做出更合适的选择。 核心优势与市场定位对比 OKX的核心竞争力体现在其全面的…

    2025年12月8日
    000
  • newt币是什么?投资价值怎么样

    newt币,全称为newton token,是牛顿项目(newton project)生态系统中的原生数字通证。它不仅仅是一种简单的加密货币,更是支撑整个项目运行、激励参与者和实现治理功能的核心工具。理解newt币,需要先了解其背后的牛顿项目。 探究NEWT币:一种去中心化生态系统中的数字代币 牛顿…

    2025年12月8日
    000
  • Payram:通过自托通道开创了稳定付款的未来

    payram让商家能够自主接受stablecoin支付。随着stablecoins在全球贸易中扮演越来越重要的角色,payram提供了一个可扩展且安全的解决方案。 Payram:通过自托管通道引领稳定支付新时代 在快速演进的数字金融领域,Payram正逐渐成长为一名重要力量,助力商家迎接支付未来。通…

    2025年12月8日
    000
  • 稳定币跟比特币有什么关联与区别

    稳定币跟比特币有什么关联与区别 稳定币与比特币同属于数字货币的范畴,都在区块链技术的基础上运行,但它们的设计初衷、价值来源和市场功用存在着本质的不同。简单来说,比特币是一种追求价值增长与去中心化自由的数字资产,而稳定币的核心目标是维持价值的稳定,充当数字世界中的“锚定货币”。 两者之间的深层联系 尽…

    2025年12月8日
    000
  • SEI Price Skyrockets:加密集会还是短暂的财富?

    在更广泛的加密货币市场回暖的推动下,sei价格正迎来一波强劲上涨。这是一次可持续的反弹,还是短暂的高峰?我们将深入探讨影响sei价格走势与市场预期的关键因素。 近期SEI价格快速攀升,引起了投资者的高度关注,许多人开始猜测这是否预示着更大的行情启动。为了厘清局势,我们来看看推动SEI价格上涨的背后力…

    2025年12月8日
    000
  • 分数NFT,AI驱动的数字所有权和NFT革命:数字资产的新时代

    探索nft的全新维度:分数化、ai驱动与数字所有权的未来。在这篇深入解析的文章中,了解nft领域正在发生的变革趋势和潜在发展方向。 NFT的世界正以前所未有的速度扩展,远远超出像素艺术的范畴。分数化NFT和人工智能技术正在重塑行业格局,使数字资产更具可访问性,并推动动态化、智能化的发展进程。 分数化…

    2025年12月8日
    000
  • 连锁链接,万事达卡和链接访问:将差距弥合到加密货币数十亿美元

    mastercard与chainlink携手合作,为30亿用户提供无缝接入加密货币的链上解决方案。这是否预示着数字支付新时代的到来? 这是什么大新闻?围绕“Chainlink、MasterCard和链上接入”的热议并非空穴来风。我们正在见证一个可能改变行业格局的合作,它有望将加密货币推向主流市场。 …

    2025年12月8日
    000
  • 脾气暴躁的AI章鱼和Web3对真正实用程序的追求:纽约人

    探索脾气暴躁的ai章鱼概念(例如paul grumpus,web3)与真实效用追求之间的交汇点,正在推动加密领域从炒作走向有形价值。 让我们面对现实吧,Web3世界看起来就像一个没有底线的马戏团。到处是喧嚣和口号,却缺乏实质内容。但现在情况似乎在转变,人们开始渴望真正有价值、可感知的东西。于是,脾气…

    2025年12月8日
    000
  • Insta360麦克风空气:无线音频进行袖珍升级

    insta360推出mic air进军无线麦克风市场,为内容创作者提供了一款体积小巧且价格亲民的解决方案,尤其适合已经使用insta360设备的用户。 Insta360 Mic Air正式加入无线麦克风行列,成为内容创作者的新选择。它体积小巧,功能强大,适用于Insta360运动相机。我们来详细了解…

    2025年12月8日
    000
  • 航空信号,交易目标和市场新闻:鲸鱼活动激发乐观

    分析围绕机场金融(aero)的鲸鱼活动,技术指标和市场动态。 aero可以收回$ 1吗?现在找出! 航空信号,交易目标和市场新闻:鲸鱼活动激发乐观 机场金融(Aero)正在升温!最近出现的鲸鱼活动显示出战略性布局,而其与基础生态系统的紧密关联则进一步推动了市场情绪。Aero能否突破关键阻力位?让我们…

    2025年12月8日
    000
  • 2025年6月的加密山羊:与Qubetics及其他

    看看2025年6月的altcoin格局,重点关注码头($tics)及其他潜力项目,如avalanche、polkadot等。 加密世界正变得热闹非凡,如果您在2025年6月忽略了Altcoins,那将错过许多机会。这并非传统的投资组合,我们正深入探索数字边界,像码头这样的项目正在掀起波澜。抓紧时间,…

    2025年12月8日
    000
  • 模因硬币躁狂症:预售收益和25年观看的加密货币

    浏览2025年的模因币热潮,聚焦预售带来的丰厚收益,并特别关注troller cat、little pepe和bitcoin solaris等加密项目。 2025年的Meme币市场异常火爆,预售阶段展现出巨大的投资回报潜力。诸如Troller Cat、Little Pepe以及Bitcoin Sol…

    2025年12月8日
    000
  • FLOKI价格预测:技术逆转信号潜在收益?

    floki inu是否即将迎来突破?解析这一模因币的最新价格走势、技术指标与未来预期。 FLOKI价格展望:反转信号显现,潜在上涨可期? Floki Inu(FLOKI)近期出现异动!最新的价格表现暗示着可能的技术性反转,市场对其短期乃至中长期走势再度燃起关注。我们来深入剖析背后的因素以及未来可能的…

    2025年12月8日
    000
  • 拖钓猫:模因硬币在2025年扑灭了吗?

    忘记道路。 troller cat($ tcat)通过堆积,游戏燃烧和真正的实用程序将其拖到顶部。这是2025年的模因硬币吗? 模因硬币市场正处于狂热状态,但可以确定的是:它不会消失。别再执着于熟悉的生活;在2025年,模因硬币的目标是实现实际价值。像喜剧演员、测试项目以及一只调皮的猫科动物这样的名…

    2025年12月8日
    000
  • SynaptoGenix,Bittensor和Corporate国库:一个新时代?

    探索synaptogenix大胆地进入bittensor(tao)以及企业加密货币库的增长趋势,包括nano labs的$ 1b bnb收购计划。 SynaptoGenix、Bittensor与Corporate国库:一个新时代? 随着越来越多的企业将数字资产纳入其战略之中,金融界正热议不断。从比特…

    2025年12月8日
    000
  • 加密公牛跑步?今天要购买的顶级山寨币!

    加密牛市临近了吗?探索bnb、morpho与aero等主流山寨币,以及如litecoin和angry pepe fork等潜在宝藏,它们都具备增长潜力。现在入手正当时! 加密牛市即将启动?值得入手的主流山寨币清单! 随着降息预期升温及比特币呈现积极走势,加密市场的牛市是否正在酝酿?精明投资者已将目光…

    2025年12月8日
    000

发表回复

登录后才能评论
关注微信