基于数值和文本动态着色HTML表格:JavaScript与CSS实践教程

基于数值和文本动态着色HTML表格:JavaScript与CSS实践教程

本教程详细介绍了如何利用javascriptcss实现html表格的动态样式控制。通过解析表格中的数值和总金额,javascript能够根据预设条件为满足目标的表格行添加背景色,并插入视觉标记(如对勾),从而提升数据展示的直观性和用户体验。文章将涵盖html结构、css样式定义以及核心javascript逻辑。

在数据展示中,尤其是在追踪进度或目标达成情况时,能够根据数据动态改变表格行的视觉样式,可以极大地提高信息的可读性和直观性。本教程将引导您完成一个实际案例,演示如何使用前端技术(HTML、CSS和JavaScript)实现这一功能:根据一个总金额,自动高亮表格中已达成的目标行,并添加一个视觉标记。

1. HTML结构:定义表格与总金额显示

首先,我们需要一个清晰的HTML结构来承载我们的数据。一个标准的表格包含

(表头)和

(表体),以及用于显示总金额的元素。为了方便JavaScript访问,我们将为表格和总金额元素分配ID。

A/A $ GOAL
1 100
2 200.25
3 500

Total $200.25

结构说明:

元素通过 id=”table-id” 标识,尽管在本例中直接通过 tbody tr 选择器即可。

定义了表格的列标题。

包含了所有数据行。每个

代表一行数据,其中第二个

元素时,该行就会变绿。.tick:after 使用 ::after 伪元素在内容后面插入一个 Unicode 对勾符号 ✓。当JavaScript将此 tick 类添加到第三个

内的所有

元素,返回一个 NodeList。document.querySelector(‘#money’) 选取了显示总金额的 元素。通过 getNumber() 函数,将 中的文本内容转换为数值并存储在 total 变量中。遍历与判断:rows.forEach(row => { … }) 遍历了获取到的每一行数据。在每次迭代中,row.querySelector(‘td:nth-child(2)’) 选取当前行的第二个

元素的 classList 中,从而使其背景变为绿色。tickCell.classList.add(‘tick’):同时,将 .tick 类添加到第三个

时,能够正确覆盖整个行的背景。如果将 td 设置为背景色,.green 类可能需要更具体的选择器(如 tbody tr.green td)才能生效。用户体验: 考虑添加CSS过渡效果(如 transition: background-color 0.3s ease; 到 tbody tr),使背景色变化更加平滑。

总结

通过本教程,我们学习了如何结合HTML、CSS和JavaScript,实现一个动态的表格样式系统。这种方法不仅能使数据展示更加生动和直观,也为更复杂的交互和数据可视化奠定了基础。通过灵活运用DOM操作和CSS类,开发者可以创建出高度响应和用户友好的网页应用。

以上就是基于数值和文本动态着色HTML表格:JavaScript与CSS实践教程的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月28日 03:39:10
下一篇 2025年11月28日 03:39:32

相关推荐

  • Typecho主题白天夜晚模式切换失效怎么办?

    typecho主题白天夜晚模式切换失效?刷新后模式丢失? 许多Typecho用户在尝试添加白天/夜晚模式切换功能后,发现切换效果无法持久,刷新页面后设置便会失效。本文提供解决方案,帮助您解决此问题。 问题描述: 按照网上教程添加白天夜晚模式切换代码到footer.php后,刷新或点击链接,模式设置无…

    2025年12月10日
    000
  • 如何用原生PHP构建网站?从语法到数据库连接的完整指南

    原生PHP网站开发:从基础语法到数据库连接 想用PHP从零开始构建网站?本文提供一些实用建议和技巧,助您快速入门。 框架优先:提升效率 直接使用原生PHP开发网站效率低下且易出错。建议学习并使用PHP框架,例如ThinkPHP5,它能提供丰富的功能和简化的开发流程,显著提高开发效率。 立即学习“PH…

    2025年12月10日
    000
  • 原生PHP建站从入门到放弃?如何高效构建我的第一个PHP网站?

    原生PHP建站:高效构建你的第一个网站 许多PHP初学者希望直接使用原生PHP构建网站,却常常感到迷茫。本文将提供一些建议,帮助你高效完成你的第一个PHP网站。 入门建议:不止是PHP语法 仅仅掌握PHP语法是不够的,你需要深入了解Web开发相关的技术。 建议学习一些常用的Web开发技术,例如HTM…

    2025年12月10日
    000
  • Vue和ThinkPHP6同域名部署:如何解决前端路由、静态资源及服务器配置难题?

    Vue和ThinkPHP6同域名部署:高效解决方案 在Vue-cli2和ThinkPHP6的同域名部署中,常常会遇到一些棘手的配置问题。本文将提供有效的解决方案,帮助您顺利完成前后端部署。 一、前端路由及服务器配置 使用history模式的Vue路由,并配置basename后,有时会显示自定义404…

    2025年12月10日
    000
  • PhpWord转HTML时,如何设置表格宽度?

    使用PhpWord将Word文档转换为HTML时,如何控制表格宽度? 将Word文档转换为HTML时,常常需要精确控制表格宽度。 本文将指导您如何使用PhpWord库实现这一目标。 首先,确保已正确加载必要的命名空间: use PhpOfficePhpWordSimpleTypeJc;use Php…

    2025年12月10日
    000
  • 本地人:您没有看到的革命

    历史上有许多被忽视或低估的旧技术,最终以颠覆性的方式重塑了行业格局。 让我们回顾Ancippo Biondi及其研究团队的杰出成就:他们巧妙地运用SAR卫星技术和深厚的科学知识,成功将声子转化为光子,从而揭示了此前未知的地下结构。这一突破性发现导致了在吉萨高原下方发现传说中的阿门蒂(Amenti)—…

    2025年12月10日
    000
  • 为什么我讨厌WordPress,但是为什么它仍然很棒和必要

    WordPress占据着超过40%的网站市场份额,是目前最流行的内容管理系统(CMS)。然而,在软件工程师群体中,特别是后端开发和可扩展Web应用领域的工程师,WordPress因其低效、臃肿和令人沮丧的特性而臭名昭著。 我个人非常不喜欢WordPress。我花费了大量时间处理其混乱的代码库、解决插…

    2025年12月10日
    000
  • 优化Laravel应用程序性能的提示

    Laravel应用的性能直接影响用户体验。本文将分享十个有效提升Laravel应用性能的技巧,涵盖缓存策略、数据库优化等方面,助您缩短加载时间,提升服务器效率,最终优化应用速度。 巧用路由缓存 重要性: Laravel每次请求都加载路由,大量路由会拖慢响应速度。路由缓存可有效解决此问题。 操作方法:…

    2025年12月10日
    000
  • 如何实现目标 去年网站技术目标的更新以及 5 月份的计划

    回顾与展望:2024年网站建设历程及2025年规划 去年年初,我曾总结了2023年的网站建设成果并展望了2024年的目标。 鉴于此文颇受读者欢迎,我决定延续这一传统,回顾2024年的工作,并规划2025年的方向。 2024年的主要目标包括: 为Symfony Station创建自定义Drupal主题…

    2025年12月10日
    000
  • 带帖子计数的 WordPress 类别

    此短代码可在您的 WordPress 网站上显示包含帖子数量的类别列表。 PHP 代码: // 显示 WordPress 类别及其帖子数量function display_categories_with_post_count() { $categories = get_categories(); $…

    2025年12月10日
    000
  • 在 WordPress 中创作 Bio Box CSS

    这段 CSS 代码创建了一个作者信息框,包含作者头像、姓名、简介和查看全部文章的链接,从而提升读者参与度。 PHP 代码: // ———————————————————- //// 作者信息框 //// ———-…

    2025年12月10日
    000
  • 如何在 Laravel 中生成发票 PDF?

    本教程演示如何在 Laravel 框架中生成 PDF 发票。我们将使用 Dompdf 库实现这一功能,并提供一个简单的示例,适用于 Laravel 6 至 Laravel 11 版本。 步骤一:安装 Laravel (可选) 如果您尚未创建 Laravel 项目,请使用以下命令安装 Laravel …

    2025年12月9日
    000
  • 探索 Laravel 目录结构的一天

    Laravel,这个优雅的PHP框架,旨在简化现代Web应用的开发。新建Laravel项目时,自带的清晰目录结构鼓励最佳实践,并实现明确的关注点分离。让我们深入了解其主要目录及用途。 Laravel 目录结构详解 一个标准Laravel安装包含以下核心目录: 项目根目录/|– app/|– bo…

    2025年12月9日
    000
  • PHP 书籍推荐

    php 和 mysql 学习资源推荐:从入门到高级 本文推荐一系列 PHP 和 MySQL 学习书籍,涵盖不同技能水平,从初学者到高级开发者都能找到合适的学习资料。 初学者 PHP 和 MySQL:忍者新手: 这本书专为初学者设计,重点讲解如何构建 Web 项目,并涵盖数据库实践、安全性和数据操作。…

    2025年12月9日 好文分享
    000
  • Sublime Text Config for Laravel

    本文档介绍了笔者使用 Sublime Text 编辑器进行 Laravel 应用开发时的配置方案。 插件 以下插件显著提升了开发效率: GitBlameGitGutterAdvancedNewFileSyncSideBarLSPLSP-intelephenseLSP-bashLSP-dockerfi…

    2025年12月9日
    000
  • 如何在 PHP 中实现缓存以及哪些缓存技术最能提高性能?

    如何在 php 中实现缓存,您更喜欢哪种缓存技术? 缓存是现代 web 应用程序中提高性能、减少服务器负载和增强用户体验的一项重要技术。通过临时存储数据以便快速访问,缓存有助于防止冗余的数据库查询或昂贵的计算。在 php 中,您可以根据您的具体用例实施各种缓存策略和技术。 在本文中,我们将讨论不同类…

    好文分享 2025年12月9日
    000
  • 如何将旧的 php 网站部署到 koyeb

    本文介绍如何将一个运行了多年的单文件PHP网站(包含SQLite数据库、图片、JS和CSS)从传统服务器迁移到Koyeb云平台。这个网站主要用于监控PHP端的情况。 迁移步骤如下: 代码版本控制: 将所有网站文件和代码上传到GitHub仓库进行版本管理。 依赖管理: 创建一个composer.jso…

    2025年12月9日
    000
  • GitHub 页面上的 Day Host 静态应用程序

    github pages 仅支持静态网站托管,无法直接运行 php 应用(如 laravel)。但可以通过导出 laravel 应用的静态前端(html、css、javascript)到 github pages。以下步骤演示如何将 laravel “hello world” 应用部署到 githu…

    2025年12月9日 好文分享
    000
  • 优化 PHP 以实现高性能 Web 应用程序

    PHP凭借其灵活性、易用性和强大的社区支持,成为构建Web应用的首选语言之一。 然而,随着应用复杂度和用户规模的增长,性能优化至关重要,才能确保流畅的用户体验。 低效的Web应用会导致转化率下降、跳出率上升以及用户体验不佳。因此,PHP性能优化不仅关乎速度,更关乎应用的成功。本文将探讨一些针对高性能…

    2025年12月9日
    000
  • Nginx和PHP7如何配合达到最佳性能

    通过协同优化 Nginx 和 PHP7,可以提升网站性能:Nginx 启用静态内容缓存、反向代理负载均衡和 GZIP 压缩。PHP7 启用 Opcache、优化数据库查询、减少内存泄漏和禁用不必要的扩展。协同优势包括缓存与动态内容分离、减少数据库查询负担、提升代码执行速度和增强服务器稳定性。 Ngi…

    2025年12月9日
    000

发表回复

登录后才能评论
关注微信
包含目标金额,第三个

将用于显示目标达成标记。

元素用于显示总金额,其中的 元素带有 id=”money”,这是JavaScript获取总金额的关键。为了简化数值解析,我们移除了金额中的货币符号,并统一使用小数点作为小数分隔符。

2. CSS样式:美化表格并定义动态效果

CSS负责表格的基本外观以及动态高亮和标记的样式。我们将定义基础的表格样式,并创建两个关键的类:.green 用于背景高亮,.tick 用于显示对勾标记。

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

table {  width: 75%;  top: 0;}th {  background-color: purple;  color: #f1f1f1;  font-size: 15px;  padding: 4px;}/* 将背景色应用于行,而非单元格,以便于动态高亮整个行 */tbody tr {  background-color: #376282;}td {  color: #fff;  font-size: 15px;  padding: 4px;  text-align: center;}#money {  background-color: gold;  color: blue;  font-size: 15px;  padding: 4px;  text-align: center;}/* 动态高亮类 */.green {  background-color: green;}/* 动态对勾标记类 */.tick:after {  content: '✓'; /* 使用CSS content属性插入对勾符号 */}

样式说明:

基础样式定义了表格的宽度、表头背景色、文字颜色和字体大小。重要调整: tbody tr 被赋予了默认的背景色 #376282。这是为了确保当JavaScript添加 .green 类时,能正确覆盖整个行的背景色,而不是仅仅覆盖单元格的背景色。#money 元素的样式使其在页面上更加突出。.green 类简单地将背景色设置为绿色。当JavaScript将此类添加到

元素时,该单元格将显示对勾。

3. JavaScript逻辑:实现动态判断与样式应用

JavaScript是实现动态行为的核心。它将负责读取总金额,遍历表格行,比较每个目标金额与总金额,并根据比较结果动态地添加或移除CSS类。

CodeSquire CodeSquire

AI代码编写助手,把你的想法变成代码

CodeSquire 103 查看详情 CodeSquire

// 辅助函数:从DOM元素的文本内容中提取数值function getNumber(el) {  return parseFloat(el.textContent);}// 1. 获取所有表格数据行和总金额const rows = document.querySelectorAll('tbody tr');const total = getNumber(document.querySelector('#money'));// 2. 遍历每一行数据rows.forEach(row => {  // 获取当前行的目标金额单元格和目标标记单元格  const sumCell = row.querySelector('td:nth-child(2)'); // 第二个td是目标金额  const tickCell = row.querySelector('td:nth-child(3)'); // 第三个td是目标标记  // 将目标金额单元格的文本内容转换为数值  const goalAmount = getNumber(sumCell);  // 3. 判断目标是否达成  if (goalAmount <= total) {    // 如果目标金额小于或等于总金额,则认为目标达成    row.classList.add('green'); // 为整行添加绿色背景    tickCell.classList.add('tick'); // 为目标标记单元格添加对勾  }});

JavaScript代码详解:

getNumber(el) 函数: 这是一个实用函数,用于从给定的DOM元素的 textContent 中提取浮点数。parseFloat() 函数能将字符串解析为浮点数,这对于处理金额字符串非常有用。DOM元素选择:document.querySelectorAll(‘tbody tr’) 选取了表格

(包含目标金额),row.querySelector(‘td:nth-child(3)’) 选取第三个

(用于显示对勾)。goalAmount 通过 getNumber() 函数获取当前行的目标金额。if (goalAmount <= total) 进行条件判断。如果当前行的目标金额小于或等于总金额,则表示该目标已达成。动态样式应用:row.classList.add(‘green’):如果条件满足,将 .green 类添加到当前

元素的 classList 中,使其显示对勾标记。

4. 整合与注意事项

将上述HTML、CSS和JavaScript代码整合到一个HTML文件中,并在浏览器中打开,您将看到表格根据总金额动态高亮和显示对勾的效果。

完整代码示例:

            动态表格高亮与状态标记            body {            font-family: Arial, sans-serif;            margin: 20px;            background-color: #282c34;            color: #f1f1f1;        }        table {            width: 75%;            border-collapse: collapse; /* 使表格边框合并 */            margin-bottom: 20px;        }        th {            background-color: purple;            color: #f1f1f1;            font-size: 15px;            padding: 8px; /* 增加内边距 */            text-align: left; /* 左对齐表头 */        }        tbody tr {            background-color: #376282;            transition: background-color 0.3s ease; /* 添加过渡效果 */        }        td {            color: #fff;            font-size: 15px;            padding: 8px; /* 增加内边距 */            text-align: center;            border: 1px solid #444; /* 添加单元格边框 */        }        #money {            background-color: gold;            color: blue;            font-size: 18px; /* 增大字体 */            padding: 8px 12px; /* 增加内边距 */            text-align: center;            border-radius: 4px; /* 圆角 */            display: inline-block; /* 确保背景色和内边距生效 */        }        /* 动态高亮类 */        .green {            background-color: green;        }        /* 动态对勾标记类 */        .tick:after {            content: '✓';            color: lime; /* 对勾颜色 */            font-weight: bold;            margin-left: 5px; /* 与数字间隔 */        }        
A/A $ GOAL
1 100
2 200.25
3 500

Total $200.25

// 辅助函数:从DOM元素的文本内容中提取数值 function getNumber(el) { return parseFloat(el.textContent); } // 1. 获取所有表格数据行和总金额 const rows = document.querySelectorAll('tbody tr'); const total = getNumber(document.querySelector('#money')); // 2. 遍历每一行数据 rows.forEach(row => { // 获取当前行的目标金额单元格和目标标记单元格 const sumCell = row.querySelector('td:nth-child(2)'); // 第二个td是目标金额 const tickCell = row.querySelector('td:nth-child(3)'); // 第三个td是目标标记 // 将目标金额单元格的文本内容转换为数值 const goalAmount = getNumber(sumCell); // 3. 判断目标是否达成 if (goalAmount <= total) { // 如果目标金额小于或等于总金额,则认为目标达成 row.classList.add('green'); // 为整行添加绿色背景 tickCell.classList.add('tick'); // 为目标标记单元格添加对勾 } });

关键注意事项:

数值解析: parseFloat() 只能处理以数字开头的字符串。如果金额中包含货币符号(如$100),需要先移除这些符号,例如使用 el.textContent.replace(/[^d.]/g, ”) 进行预处理,才能正确解析。本教程中已简化HTML,直接提供纯数字。小数分隔符: 确保您的金额数据统一使用小数点作为小数分隔符(例如 100.25),而不是逗号(例如 100,25),因为 parseFloat() 默认识别小数点。CSS优先级: 将 tbody tr 的背景色设置为默认值,而不是 td,是为了确保当 .green 类添加到