如何使用 JavaScript 精确统计 HTML 表格中非空行的数量
发布时间 - 2026-01-31 00:00:00 点击率:次本文介绍如何通过 jquery 或原生 javascript 过滤掉 html 表格中内容全为空(如仅含空白符、空标签)的 `
在处理动态或手动编辑的 HTML 表格时,常会遇到“看似有行、实则无数据”的情况——例如仅含空
要精准统计非空行(即至少有一个单元格包含可见文本内容),关键在于:对每一行提取其全部文本内容 → 去除首尾空白 → 判断是否为空字符串。
✅ 推荐方案:使用 jQuery + filter()(更健壮、语义清晰)
? $.trim() 自动处理各种空白字符(空格、\t、\n、\r),比直接比较 "\t\t" 更可靠,且不受 HTML 缩进格式影响。
✅ 替代方案:纯 JavaScript(无需 jQuery)
document.addEventListener('DOMContentLoaded', () => {
document.querySelector('button').addEventListener('click', () => {
const rows = document.querySelectorAll('#myTable tr');
const nonEmptyCount = Array.from(rows).filter(row =>
row.textContent.trim() !== ''
).length;
alert(`非空行数量:${nonEmptyCount}`);
});
});⚠️ 注意事项
- 表头 和脚部
中的行也参与统计:若需排除
行(如仅统计 数据行),请改用 $("#myTable tbody tr") 或 document.querySelectorAll('#myTable tbody tr')。- 隐藏行(display: none)仍被计入:如需跳过隐藏行,可在过滤条件中追加 && $(this).is(':visible')(jQuery)或 row.offsetParent !== null(原生)。
- 空单元格含 或零宽字符? textContent.trim() 可覆盖常见空白,但若存在 Unicode 零宽空格(U+200B)等特殊字符,建议额外正则清洗:.replace(/[\u200B-\u200D\uFEFF]/g, '').trim()。
✅ 总结
统计非空行的本质是内容校验而非结构计数。避免依赖固定字符串匹配(如 "\t\t"),而应统一使用 textContent + trim() 判断逻辑有效性。该方法兼容各种 HTML 缩进风格、空标签组合及富文本场景,是生产环境推荐的稳健实践。
# javascript
# java
# jquery
# html
# js
# ajax
# cdn
# NULL
# Filter
# 字符串
# Length
# this
# display
# tbody
# td
# tr
# th
# 为空
# 单元格
# 不受
# 可在
# 而非
# 如需
# 关键在于
# 跳过
# 偏高
# 有一个
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
JavaScript 输出显示内容(document.write、alert、innerHTML、console.log)
Laravel怎么实现模型属性的自动加密
北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?
Laravel如何使用Blade组件和插槽?(Component代码示例)
香港服务器建站指南:外贸独立站搭建与跨境电商配置流程
ChatGPT常用指令模板大全 新手快速上手的万能Prompt合集
详解Nginx + Tomcat 反向代理 如何在高效的在一台服务器部署多个站点
利用 Google AI 进行 YouTube 视频 SEO 描述优化
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
Laravel怎么调用外部API_Laravel Http Client客户端使用
如何在阿里云虚拟主机上快速搭建个人网站?
Win11怎么设置虚拟桌面 Win11新建多桌面切换操作【技巧】
如何用美橙互联一键搭建多站合一网站?
如何快速搭建自助建站会员专属系统?
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布
实例解析Array和String方法
Claude怎样写结构化提示词_Claude结构化提示词写法【教程】
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
打造顶配客厅影院,这份100寸电视推荐名单请查收
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
中国移动官方网站首页入口 中国移动官网网页登录
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】
Angular 表单中正确绑定输入值以确保提交与验证正常工作
如何在局域网内绑定自建网站域名?
Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程
文字头像制作网站推荐软件,醒图能自动配文字吗?
网站建设要注意的标准 促进网站用户好感度!
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
如何在橙子建站中快速调整背景颜色?
Laravel如何实现数据导出到CSV文件_Laravel原生流式输出大数据量CSV【方案】
高端建站三要素:定制模板、企业官网与响应式设计优化
Laravel表单请求验证类怎么用_Laravel Form Request分离验证逻辑教程
JavaScript如何实现类型判断_typeof和instanceof有什么区别
Laravel怎么定时执行任务_Laravel任务调度器Schedule配置与Cron设置【教程】
Laravel如何使用Livewire构建动态组件?(入门代码)
Laravel Eloquent关联是什么_Laravel模型一对一与一对多关系精讲
网站制作大概多少钱一个,做一个平台网站大概多少钱?
Python函数文档自动校验_规范解析【教程】
Laravel如何使用Telescope进行调试?(安装和使用教程)
高防服务器:AI智能防御DDoS攻击与数据安全保障
深圳防火门网站制作公司,深圳中天明防火门怎么编码?
专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?
黑客如何利用漏洞与弱口令入侵网站服务器?
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
如何在阿里云完成域名注册与建站?
js实现点击每个li节点,都弹出其文本值及修改
html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】
百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭

