前言
在实际工作过程中给,经常会遇到将超出长度的文字显示为省略号的需求。下面对几种方法进行下记录总结。
正文
单行
.class{
width: 400px;
overflow: hidden; //这个是设置隐藏的。还有其他的,例如scroll,是超出固定长度,底部显示滚动条的。
text-overflow: ellipsis; //这个就是设置直接隐藏掉文字,还是显示...的。当前是显示省略号。直接省略是clip
display: inline-block; //根据不同标签display值,有的不用加。
white-space: nowrap;/**不换行**/
}
多行
.class{
overflow: hidden;
text-overflow: ellipsis;
-webkit-line-clamp: 2; //这里就是设置超出几行隐藏
-webkit-box-orient: vertical;
display:-webkit-box; //根据不同标签display,有的不用加。或者设置成别的属性,自己可以随便试试
}
注意
有的时候,你按照上面的设置。就是不生效。或者本地生效了,react(或者vue)打包到服务器上就不生效了。你可以在控制台看看。是不是-webkit-box-orient这个属性消失了。如果是这样的话,请看下面的解决办法。
- 方法1
直接在style里面写上 display:-webkit-box;就行 - 方法2
.class{
overflow: hidden;
text-overflow: ellipsis;
-webkit-line-clamp: 2;
/* autoprefixer: off */ //对,就是加这两个注释就行。
-webkit-box-orient: vertical;
/* autoprefixer: on */
display:-webkit-box;
}