日期:2013-08-14  浏览次数:21007 次

  看到标题你一定很容易就会想到截断文字加“...”的做法。哈哈,就是这样。其实写这篇日志也只是把这样方法做个记录,由于好像还有很多人不记得遇到这样的情况该如何处理。

  我们也可以参考52CSS.com以前的文章:
  CSS对文字溢出时的自动隐藏处理http://www.Aiyiweb.Com/htmldata/2007-05-05/1178374126.html
  如何设置列表(li)超出部分显示省略号http://www.Aiyiweb.Com/htmldata/2007-05-05/1178374241.html

  普通的文字截断(适用于内联与块):

.text-overflow {
display:block;/*内联对象需加*/
width:31em;
word-break:keep-all;/* 不换行 */
white-space:nowrap;/* 不换行 */
overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */
text-overflow:ellipsis;/* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一同使用。*/
}

  对于表格文字溢出的定义:

table{
width:30em;
table-layout:fixed;/* 只要定义了表格的规划算法为fixed,下面td的定义才能起作用。 */
}
td{
width:100%;
word-break:keep-all;/* 不换行 */
white-space:nowrap;/* 不换行 */
overflow:hidden;/* 内容超出宽度时隐藏超出部分的内容 */
text-overflow:ellipsis;/* 当对象内文本溢出时显示省略标记(...) ;需与overflow:hidden;一同使用。*/
}

  需求你留意的是,这个东东只对单行的文字的效,如果你想把它用在多行上,也只要第一行有作用的。 这个写法只要IE会有“...”,其它的浏览器文本超出指定宽度时会隐藏。