现在的位置: 网页制作教程网站制作经验 >正文
CSS

如何利用CSS控制文本只在一行显示(不换行)

发表于2014/6/13 网站制作经验 0条评论 ⁄ 热度 3,461℃

我们在做前端时,经常会要求文字只在一行显示。当一行文字超过DIV或者Table的宽度的时候,浏览器中默认是让它换行显示的,如果不想让他换行要怎么办呢?通过CSS中的word-break,white-space可以达到不换行的效果。

用CSS让文字在一行内显示不换行的方法

一般的文字截断(适用于内联与块):

.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会有"...",其它的浏览器文本超出指定宽度时会隐藏。

  • 暂无评论