怎么用纯CSS实现表格响应式布局

布局效果:

怎么用纯CSS实现表格响应式布局

简单解析一下效果:

  • 在屏幕视口较为宽时,表现为一个整体 Table 的样式

  • 而当屏幕视口宽度较小时,原 Table 的每一行数据单独拆分为一个 Table 进行展示

很有意思的一个响应式布局,让信息在小屏幕下得到了一种不错的展示。

那么,仅仅使用 CSS 的话,能否实现这样一个布局呢?答案是可以的

首先,肯定会用到媒体查询,这个不难看出。另外,我们观察下拆分后的每一组数据:

怎么用纯CSS实现表格响应式布局

都会存在一组原本整体一个 Table 时的表头信息,主要的难点就是在这里,我们如何在拆分成一个一个的子 Table 展示时,同时展示这些表头信息?

基本结构的实现

首先,我们先实现常规宽屏下的 HTML 及对应的 CSS。

比较简单,这里没有什么特殊之处,使用 <table> 标签或者使用 div、ul 等标签进行模拟一个表格都可以。

<table>  <caption>Lorem ipsum !</caption>  <thead>    <tr>      <th>Account</th>      <th>Due Date</th>      <th>Amount</th>      <th">Period</th>    </tr>  </thead>  <tbody>    <tr>      <td data-label="Account">Visa - 3412</td>      <td data-label="Due Date">04/01/2016</td>      <td data-label="Amount">$1,190</td>      <td data-label="Period">03/01/2016 - 03/31/2016</td>    </tr>    // ... 重复多组  </tbody></table>

得到这样一个简单的 Table:

怎么用纯CSS实现表格响应式布局

使用媒体查询将单个 Table 拆分成多个

下一步也很简单,设定合适的阈值(视实际业务情况而定),使用媒体查询将单个 Table 拆分成多个子 Table。

@media screen and (max-width: 600px) {  table {    border: 0;  }    table thead {    display: none;  }  table tr {    display: block;    margin-bottom: 10px;  }  table td {    border-bottom: 1px solid #ddd;    display: block;  }}

这里做的事情也非常简单:

  • 利用媒体查询,设定屏幕宽度小于 600px 的样式

  • 去掉原本表格的 <thead> 表头,直接隐藏即可

  • 将原本的一行 <tr>,设置为 display: block, 并且设置一个下边距,使之每一个分开

  • 将原本的一行内的 <td>,设置为 display: block,这样,它们就会竖向排列,使每一个 <tr> 形成新的一个子 table

好,这样,再屏幕宽度小于 600px 时,我们就得到了这样一个 Table:

怎么用纯CSS实现表格响应式布局

借助伪元素及其特性,实现表头信息展示

下面一步,也就是最为关键的一步,我们如何在子 table 的每一行,也就是 <td> 内,再展示原本的表头信息呢?

这里其实也非常简单,只是简单的运用了伪元素,极其可以读取 HTML 标签属性的小特性实现。

我们只需要简单改造一下代码,给每个 <td> 的 HTML,带上与之对应的表头列描述信息:

<table>  // 上方信息保持一致  <tbody>    <tr>      <td data-label="Account">Visa - 3412</td>      <td data-label="Due Date">04/01/2016</td>      <td data-label="Amount">$1,190</td>      <td data-label="Period">03/01/2016 - 03/31/2016</td>    </tr>    <tr>      <td scope="row" data-label="Account">Visa - 6076</td>      <td data-label="Due Date">03/01/2016</td>      <td data-label="Amount">$2,443</td>      <td data-label="Period">02/01/2016 - 02/29/2016</td>    </tr>    // ... 每个 tr 进行同样的处理  </tbody></table>

接着,借助 td 的伪元素,实现表头信息的展示即可:

@media screen and (max-width: 600px) {  // ... 保持一致  table td {    position: relative;    display: block;    text-align: right;  }  table td::before {    position: absolute;    left: 10px;    right: 0;    content: attr(data-label);  }}

这里,我们核心的知识点就是利用了元素的伪元素可以在 content 属性里,读取其 HTML 元素内的属性内容,并进行展示的知识点。

  • 假设一个 HTML 标签定义为: <div data-msg="ABC">

  • 那么该 div 对应的伪类如果设置了 content: attr(data-msg) ,就可以读取到 data-msg 的值,相当于 content:"ABC"

这样,我们在小屏幕下,就得到了这样一种效果:

怎么用纯CSS实现表格响应式布局

完整的效果,即如题图所示:

怎么用纯CSS实现表格响应式布局

感谢各位的阅读,以上就是“怎么用纯CSS实现表格响应式布局”的内容了,经过本文的学习后,相信大家对怎么用纯CSS实现表格响应式布局这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

文章标题:怎么用纯CSS实现表格响应式布局,发布者:亿速云,转载请注明出处:https://worktile.com/kb/p/24365

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022年9月10日 下午11:57
下一篇 2022年9月10日 下午11:59

相关推荐

  • windows证照之星如何换背景色

    证照之星换背景色的方法 1、 打开证照之星软件,添加图片之后点击选项栏的“背景处理”选项按钮。 2、点击选项后会跳出下图所示的界面内容。 3、背景处理中有涂抹功能和清除功能,分别是画出抠图范围和擦掉抠图范围。 4、完成达到自身要求的抠图后点击“处理”按钮, 然后可以为抠出来的图像选择证照之星软件自带…

    2022年9月26日
    22300
  • daisyUI怎么解决TailwindCSS堆砌class问题

    daisyUI概述 daisyUI是一个可定制的TailwindCSS的组件库,目前(发文日期)在GitHub中已经有12.8k的star数量。 它与现在常用的ElementUI或者AntDesign不同,它提供了一些类名,类似于Bootstrap,想要拿来即用的组件需要自己进行封装。 daisyU…

    2022年8月30日
    48000
  • windows丢包率高如何解决

    解决方法: 1、有些情况是因为线路故障导致的,这种情况需要和线路的供应商来进行解决。 2、对于设备方面来说,很多都是设置不当和网络接口的光纤收发器故障导致的。 3、还有就是网络的问题,比如病毒和网线的连接距离太长导致的网络故障, 还有操作系统的问题,比如网卡问题和网络运营线路问题,可以尝试使用pin…

    2022年8月29日
    62400
  • SpringBoot项目中怎么实现MySQL读写分离

    1、MySQL主从复制 但我们仔细观察我们会发现,当我们的项目都是用的单体数据库时,那么就可能会存在如下问题: 读和写所有压力都由一台数据库承担, 压力大 数据库服务器磁盘损坏则 数据丢失 ,单点故障 为了解决上述提到的两个问题,我们可以准备两 (多) 台MySQL,一台主( Master )服务器…

    2022年9月15日
    17400
  • Vue常见报错问题怎么解决

    一、报错结构 报错信息一般会包含这几部分:错误类型、错误位置、错误描述、错误规则和问题数量。 如上图: 报错类型为编译错误; 错误位置在D:myelsrcviewsadminAdminView.vue中的第四行第2个字符;(报错位置不一定每次都是准确的,但是可以根据提示缩小范围) 错误描述 当前错误…

    2022年9月20日
    35900
  • Word字体放大如何操作

    Word字体放大的方法 1、首先电脑打开word文档。 2、然后选中自己要放大的文字。 3、选中要放大的文字后,同时按住Ctrl+SHift+>就可以把文字无限放大, 想放多大就可以放多大。 4、选中文字按Ctrl+Shift+<就可以缩小文字 关于“Word字体放大如何操作”这篇文章的…

    2022年9月15日
    82900
  • 怎么强化MySQL的安全

    名列前茅步:设置强密码 对于所有数据库用户来说,使用强密码很重要。鉴于大多数人不会经常手动登录数据库,请使用密码管理器或命令行工具 pwgen 为你的数据库帐户创建一个随机的 20 个字符的密码。即使你使用额外的 MySQL 访问控制来限制特定帐户可以登录的位置(例如将帐户严格限制为 localho…

    2022年9月20日
    12600
  • css如何使用​禁用鼠标事件

    禁用鼠标事件 CSS3 新增的 pointer-events 让你能够禁用元素的鼠标事件,例如,一个连接如果设置了下面的样式就无法点击了。 .disabled { pointer-events: none; } 关于“css如何使用禁用鼠标事件”这篇文章就分享到这里了,希望以上内容可以对大家有一定的…

    2022年9月1日
    20700
  • vlookup函数匹配不出来的原因是什么

    vlookup函数匹配不出来的原因 一、单元格空白 1、首先任选一个单元格,输入“=E2=A9”,回车查看结果。 2、如果和图示一样,显示“FALSE”,说明原本应该一致的“E2”和“A9”并不一致。 3、接着我们在对应一列中使用“LEN”函数,可以看到数值不一样,一个3一个5。 4、这时候,我们只…

    2022年9月24日
    1.1K00
  • windows KB4525245安装失败怎么解决

    根据情况可能不同,小编准备了五种解决方案 名列前茅种方案: 1.查看【windows update】、【app readiness】、【Cryptographic Services】、【Background Intelligent Transfer Service】、【Windows Install…

    2022年9月1日
    24200
联系我们
站长微信
站长微信
电话联系

400-800-1024

工作日9:30-21:00在线

分享本页
返回顶部