表格单元格内容超出时显示省略号效果(实现代码)

所属分类: 网页制作 / 应用技巧 阅读数: 1972
收藏 0 赞 0 分享

说明

在前端开发中,经常会遇到需要限制单元格宽度并且内容超出部分显示省略号的的情况。下面就简单的介绍下如何达到这种效果。

准备知识

1. 控制文本不换行

white-space: nowrap;

2. 超出长度时,出现省略号

overflow:hidden;

text-overflow:ellipsis

3. 修改表格布局算法

table-layout:fixed;table-layout的默认值为automatic,意思是列宽度由单元格内容设定。而fixed意思是列宽由表格宽度和列宽度设定。

也就是说当你给表格设定列宽时,实际情况是不起作用的,当单元格内容过多时,依然会把宽度撑开。如果需要让表格的列宽显示方式由自己给单元格定义的列宽决定,就必须使用fixed这个值。

注意:1、表格必须设置宽度 2、如果只设置表格宽度,而不设置列宽度的话,列的宽度会平均分配。

代码演示

如下代码所示,表格中安排了姓名、年龄、性别以及地址四列,这几个列的长度分别为10%、20%、30%、40%。

XML/HTML Code复制内容到剪贴板
  1. <!doctype html>  
  2. <html lang="en">  
  3. <head>  
  4.     <meta charset="UTF-8" />  
  5.     <title>表格演示</title>  
  6.     <style type="text/css">  
  7.         table{   
  8.             width: 100%;   
  9.             table-layout: fixed;   
  10.         }   
  11.         .name{   
  12.             width: 10%;   
  13.         }   
  14.         .age{   
  15.             width: 20%;   
  16.         }   
  17.         .sex{   
  18.             width: 30%;   
  19.         }   
  20.         .addr{   
  21.             width: 40%;   
  22.         }   
  23.            
  24.     </style>  
  25. </head>  
  26. <body>  
  27.     <table border="1" cellspacing="0" cellpadding="0">  
  28.         <thead>  
  29.             <tr>  
  30.                 <th class="name">姓名</th>  
  31.                 <th class="age">年龄</th>  
  32.                 <th class="sex">性别</th>  
  33.                 <th class="addr">地址</th>  
  34.             </tr>  
  35.         </thead>  
  36.         <tbody>  
  37.             <tr>  
  38.                 <td>李四</td>  
  39.                 <td>13</td>  
  40.                 <td></td>  
  41.                 <td>山东</td>  
  42.             </tr>  
  43.             <tr>  
  44.                 <td>李四</td>  
  45.                 <td>13</td>  
  46.                 <td></td>  
  47.                 <td>山东</td>  
  48.             </tr>  
  49.             <tr>  
  50.                 <td>李四</td>  
  51.                 <td>13</td>  
  52.                 <td></td>  
  53.                 <td>山东</td>  
  54.             </tr>  
  55.         </tbody>  
  56.     </table>  
  57. </body>  
  58. </html>  

显示效果如下所示:

很容易可以看出,姓名、年龄、性别以及地址等列的长度分别是10%、20%、30%、40%。

如果将第一个的姓名内容增多,效果简直不忍直视(>﹏<)!

不忍直视(>﹏<)!!

 如何把单行内容超出部分显示为省略号呢?只需要将单元格设置如下属性:

XML/HTML Code复制内容到剪贴板
  1. white-space: nowrap;/*控制单行显示*/   
  2. overflow: hidden;/*超出隐藏*/   
  3. text-overflow: ellipsis;/*隐藏的字符用省略号表示*/  

话不多说,上代码!
XML/HTML Code复制内容到剪贴板
  1. <!doctype html>  
  2. <html lang="en">  
  3. <head>  
  4.     <meta charset="UTF-8" />  
  5.     <title>表格演示</title>  
  6.     <style type="text/css">  
  7.         table{   
  8.             width: 100%;   
  9.             table-layout: fixed;   
  10.         }   
  11.         .name{   
  12.             width: 10%;   
  13.         }   
  14.         .age{   
  15.             width: 20%;   
  16.         }   
  17.         .sex{   
  18.             width: 30%;   
  19.         }   
  20.         .addr{   
  21.             width: 40%;   
  22.         }   
  23.         td{   
  24.             white-space: nowrap;/*控制单行显示*/   
  25.             overflow: hidden;/*超出隐藏*/   
  26.             text-overflow: ellipsis;/*隐藏的字符用省略号表示*/   
  27.         }   
  28.     </style>  
  29. </head>  
  30. <body>  
  31.     <table border="1" cellspacing="0" cellpadding="0">  
  32.         <thead>  
  33.             <tr>  
  34.                 <th class="name">姓名</th>  
  35.                 <th class="age">年龄</th>  
  36.                 <th class="sex">性别</th>  
  37.                 <th class="addr">地址</th>  
  38.             </tr>  
  39.         </thead>  
  40.         <tbody>  
  41.             <tr>  
  42.                 <td class="name2">李四sssssssssssssssssssssssssssssssssss</td>  
  43.                 <td>13</td>  
  44.                 <td></td>  
  45.                 <td>山东</td>  
  46.             </tr>  
  47.             <tr>  
  48.                 <td>李四</td>  
  49.                 <td>13</td>  
  50.                 <td></td>  
  51.                 <td>山东</td>  
  52.             </tr>  
  53.             <tr>  
  54.                 <td>李四</td>  
  55.                 <td>13</td>  
  56.                 <td></td>  
  57.                 <td>山东</td>  
  58.             </tr>  
  59.         </tbody>  
  60.     </table>  
  61. </body>  
  62. </html>  

修改后,效果如下:

以上这篇表格单元格内容超出时显示省略号效果(实现代码)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

32个典型的以分栏/网格为基础的网站

如果你正在寻找网页分栏设计的灵感,这里收集了32个典型的以分栏/网格为基础的网站。它们显示了在网页设计中分栏/网格的重要性,无论对于信息量巨大的站点还是个人博客。 1.The New York Times 2.National Post 3.Guardian 4.Times
收藏 0 赞 0 分享

理论普及——用户体验

一、概念分析1:UE用户体验 英文叫做user experience,缩写为UE, 或者UX。 当指电子商务网站的时候也被称作顾客体验(CUSTOMER EXPERIENCE). 它是指用户访问一个网站或者使用一个产品时的全部体验。他们的印象和感觉,是否成功,是否享
收藏 0 赞 0 分享

分页案例和好的实践

结构和层次降低了复杂性并提高了可读性。你的文章或站点组织的越深入,用户就越容易理解你观点和得到你想传达的信息。在网页上,这点被通过多个方式做到。 在正文头条和列举被用做逻辑上独立的数据块来呈现信息。另一种解决方法是一种叫分页的机制,它在给定文章的单一部
收藏 0 赞 0 分享

建立用户体验

也许你刚刚来到一家公司,他们希望进行一些“可用性”工作。你可能是一名UI设计师,业务分析师,或前端开发人员,一名产品经理,或者负责用户体验部门的经理或副总。你知道,如果更好地了解使用产品/软件/网站的人,就可能开发出更好的产品/软件/网站。不管怎么样
收藏 0 赞 0 分享

网页图片快速显示的方法和技巧

1. Use .gifs rather than .jpgs. GIFs are smaller in size when compared to JPGs. 1.用.gifs格式保存图片,最好不要用.jpgs格式。因为前者的尺寸比后者小。 2.Use 'Height
收藏 0 赞 0 分享

推荐60种分页案例和好的实践

结构和层次降低了复杂性并提高了可读性。你的文章或站点组织的越深入,用户就越容易理解你观点和得到你想传达的信息。在网页上,这点被通过多个方式做到。 在正文头条和列举被用做逻辑上独立的数据块来呈现信息。另一种解决方法是一种叫分页的机制,它在给定文章的单一部
收藏 0 赞 0 分享

全面的网站评估方案

有时会被问到“看看XXX网站如何?”之类的问题。 谈到评估,通常都是指产品级的网站,如果模式很新,了解需要花一定时间。于是,很多人又问“那么你仅从UI/UE的角度看看呢?”首先我们得达成共识,一切花里胡哨都在为功能服务,如果功
收藏 0 赞 0 分享

网页的栅格设计思考

原文地址:http://andymao.com/andy/post/82.html 网页设计中的脏、乱、差,是我们在设计过程中常会遇到的问题。通常"脏"是由对色彩使用不当所产生的,而色彩使用不当产生的不好效果也分为:"花、灰",花哨、
收藏 0 赞 0 分享

设计理论设计中的层次感

原文:http://andymao.com/andy/post/80.html 这段时间我一直在说设计需要有层次感,这种层次感可能有很多类型,比如色彩的层次感,或是元素的层次感。当一个设计缺乏层次感的时候页面所表现出来的无非是两种可能,一种是单调,一种是花哨。在设计中我们常
收藏 0 赞 0 分享

网页心得:网页色彩的搭配

网页的色彩是树立网站形象的关键之一,色彩搭配却是网友们感到头疼的问题。网页的背景,文字,图标,边框,超链接...,应该采用什么样的色彩,应该搭配什么色彩才能最好的表达出预想的内涵呢?这里谈一些心得,希望对你有所启发。 首先我们先来了解一些色彩的基本知识:
收藏 0 赞 0 分享
查看更多