0

0

使用 jQuery 实现展开/折叠行功能

心靈之曲

心靈之曲

发布时间:2025-09-27 11:58:43

|

857人浏览过

|

来源于php中文网

原创

使用 jquery 实现展开/折叠行功能

本文将介绍如何使用 jQuery 实现表格行的展开和折叠功能,使数据展示更具用户友好性。通过重构 HTML 结构和调整 jQuery 代码,可以轻松地将相关内容分组,并实现点击表头展开或折叠对应内容的功能,提高用户体验。

HTML 结构重构

原始代码的问题在于 jQuery 选择器 $header.next() 仅选择紧随标题行的第一个兄弟元素。为了正确地展开/折叠所有关联的行,我们需要修改 HTML 结构,将标题行和所有内容行包裹在一个容器中。

以下是修改后的 HTML 结构示例:

Name
Date/Time
Phone
PAX
Description
Table
New
Mitchell Admin
2022-05-30 10:00:00
+1 555-555-5555
1
Confirm
Mitchell Admin
2022-06-17 12:00:00
+1 555-555-5555
1
Mitchell Admin
2022-05-30 10:00:00
+1 555-555-5555
1

在这个结构中,.pointer 容器包含了标题行 (.header) 和所有对应的内容行 (.content)。

jQuery 代码修改

接下来,我们需要修改 jQuery 代码以适应新的 HTML 结构。

睿拓智能网站系统-网上商城
睿拓智能网站系统-网上商城

睿拓智能网站系统-网上商城1.0免费版软件大小:5M运行环境:asp+access本版本是永州睿拓信息专为电子商务入门级用户开发的网上电子商城系统,拥有产品发布,新闻发布,在线下单等全部功能,并且正式商用用户可在线提供多个模板更换,可实现一般网店交易所有功能,是中小企业和个人开展个人独立电子商务商城最佳的选择,以下为详细功能介绍:1.最新产品-提供最新产品发布管理修改,和最新产品订单查看2.推荐产

下载
$(".pointer .header").click(function() {
  let parent = $(this).closest('.pointer');
  //getting the next element
  $content = parent.find('.content');
  //open up the content needed - toggle the slide- if visible, slide up, if not slidedown.
  $content.slideToggle(500, function() {
    //execute this after slideToggle is done
    //change text of header based on visibility of content div
    parent.find('.header-text').toggleClass('active');
  });

});

这段代码做了以下修改:

  1. 事件绑定:点击事件绑定到 .pointer .header,确保只有点击标题行才会触发展开/折叠。
  2. 查找父容器: 使用 $(this).closest('.pointer') 找到包含当前标题行的 .pointer 容器。
  3. 查找内容行: 使用 parent.find('.content') 在父容器中查找所有内容行。
  4. 展开/折叠内容: 使用 slideToggle() 函数实现展开和折叠的动画效果。
  5. 切换状态: 使用 toggleClass('active') 切换 .header-text 的 active 类,用于改变展开/折叠状态的显示。

CSS 样式调整

为了配合展开/折叠功能,可以添加一些 CSS 样式来改变标题行的显示状态。

.orders {
  display: flex;
  flex-flow: column nowrap;
  overflow: hidden;
  overflow-y: auto;
  margin-left: 0px;
}

.header-row {
  display: flex;
  flex-flow: row nowrap;
  flex: 1;
  justify-content: space-evenly;
  background: #868686;
  color: white;
}

.header {
  background: black;
  color: white;
  font-weight: bolder;
}

.pointer {
  cursor: pointer;
}

.orders .order-row {
  display: flex;
  flex-flow: row nowrap;
  flex: 1;
  justify-content: space-evenly;
}

.orders .col.start {
  justify-content: flex-start;
}

.orders .col {
  display: flex;
  flex: 1;
  padding: 10px;
}

.header-text .header-status:before {
    content: '- Collapse';
    display: inline;
}

.header-text.active .header-status:before {
    content: '+ Expand';
}

这段 CSS 代码添加了展开/折叠状态的指示符,在标题行显示 + Expand 或 - Collapse。

总结

通过重构 HTML 结构和修改 jQuery 代码,我们可以实现一个更健壮、更易于维护的展开/折叠行功能。这种方法不仅解决了原始代码的问题,还提供了一个更清晰的结构,方便后续的扩展和修改。记住,良好的 HTML 结构是实现复杂功能的基石。

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

150

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

310

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

394

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

502

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

181

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

120

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

174

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

35

2026.01.13

菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 22.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号