前端页面中文本标签单行省略以及多行省略

前端页面中文本标签单行省略以及多行省略

在最初的切图生涯中,页面上的很多文本内容或多或少,有时候就是要求超出部分显示为省略号,当然也可能会要求为单行溢出或多行溢出。

单行溢出的话:

width:value;            //定义容器宽度
white-space:nowrap;     //强制文本在单行显示
overflow:hidden;        //溢出隐藏
text-overflow:ellipsis;    //溢出文本显示为省略号

多行溢出:

在WebKit浏览器或移动端(绝大部分是WebKit内核的浏览器)的页面实现比较简单,可以直接使用WebKit的CSS扩展属性(WebKit是私有属性)-webkit-line-clamp ;注意:这是一个 不规范的属性(unsupported WebKit property),它没有出现在 CSS 规范草案中。

-webkit-line-clamp用来限制在一个块元素显示的文本的行数。 为了实现该效果,它需要组合其他的WebKit属性。常见结合属性:

display: -webkit-box; 必须结合的属性 ,将对象作为弹性伸缩盒子模型显示 。

-webkit-box-orient 必须结合的属性 ,设置或检索伸缩盒对象的子元素的排列方式 。

text-overflow: ellipsis;,可以用来多行文本的情况下,用省略号“…”隐藏超出范围的文本。

这个属性只合适WebKit浏览器或移动端(绝大部分是WebKit内核的)浏览器

display: -webkit-box;         //必须结合的属性 ,将对象作为弹性伸缩盒子模型显示 。
-webkit-box-orient;          //必须结合的属性 ,设置或检索伸缩盒对象的子元素的排列方式 。
text-overflow: ellipsis;     //可以用来多行文本的情况下,用省略号“…”隐藏超出范围的文本 。
overflow : hidden;           
text-overflow: ellipsis;
display: -webkit-box;        
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;

 

跨浏览器兼容的方案
比较靠谱简单的做法就是设置相对定位的容器高度,用包含省略号(…)的元素模拟实现;

p {
    position:relative;
    line-height:1.4em;
    /* 3 times the line-height to show 3 lines */
    height:4.2em;
    overflow:hidden;
}
p::after {
    content:"...";
    font-weight:bold;
    position:absolute;
    bottom:0;
    right:0;
    padding:0 20px 1px 45px;
    background: -webkit-linear-gradient(left, transparent, #fff 55%);
    background: -o-linear-gradient(right, transparent, #fff 55%);
    background: -moz-linear-gradient(right, transparent, #fff 55%);
    background: linear-gradient(to right, transparent, #fff 55%);
}

适用范围:
该方法适用范围广,但文字未超出行的情况下也会出现省略号,可结合js优化该方法。

注:

  1. 将height设置为line-height的整数倍,防止超出的文字露出。
  2. 给p::after添加渐变背景可避免文字只显示一半。
  3. 由于ie6-7不显示content内容,所以要添加标签兼容ie6-7(如:);兼容ie8需要将::after替换成:after。

你可能感兴趣的:(前端页面中文本标签单行省略以及多行省略)