多行文字精炼消除方案,界面样式

By admin in 4858美高梅 on 2019年4月4日

怎么样?那是要做前端的旋律吗?只要集团有必要,作者分分钟变身、前端、美术工作、UI、交互、后端、数据库管理员……连忙学习、火速响应,火速适应。集团索要自己干啥,小编就干啥,而小编存在于集团的意义便是选择所学的东西帮公司化解难点……事实上,如若让1个人来解决一切项目包括移动端、PC端等等,这您还不是被逼得啥都会。

WebKit浏览器或运动端的页面
在WebKit浏览器或移动端(绝当先八分之四是WebKit内核的浏览器)的页面完毕比较简单,能够直接运用WebKit的CSS扩充属性(WebKit是私有属性)-
webkit-line-clamp;多行文字精炼消除方案,界面样式。专注:那是八个 不正规的性质(unsupported WebKit
property),它从不出现在
CSS 规范草案中。

-webkit-line-clamp 多行文字溢出…,webkitlineclamp

前言

在css的利用中,大家通常性的需求对溢出文件举行处理,在实际的门类中,由于文字内容的长短不显眼和页面布局的固定性,难免会现身文字内容超越div(或别的标签,下同)区域的意况,此时可比好的做法正是当文字超越限定的div宽度后自动以省略号(…)呈现,那样,依据习惯,人们都会通晓那时候有文字被略去了。

在css中有个属性叫做text-overflow:ellipsis;卓殊别的部分特性能够兑现IE,chrome,safria浏览器下文字溢出点点点省略号展现,在抬高opera浏览器的私有属性-o-text-overflow:ellipsis;就当前而言,能够着力达成Firefox浏览器以外的具有主流浏览器的文字溢出点点点省略号呈现。

垂直居中+自动换行

体制效果如下所示,当文字未有超越壹行时,展现如“备注音信”,当文字超出1行时,显示如“维修地方”

4858美高梅 1

HTML代码如下:

                    <div class="mui-input-row multi-line">
                        <div class="box label-right">
                            <div class="div-leftauto">维修地点</div>
                            <div class="wrap">广东省深圳市南山区西丽街道桃源路1001号</div>
                        </div>
                    </div>

css样式如下:

/*不固定高宽div垂直居中的方法:其它页用*/
.box {width: 100%;height: 40px;border: 1px solid #FFF;display: table;margin-right:5px;}
.wrap{display: table-cell; vertical-align: middle; width: 100%;padding: 6px 0px;line-height: 26px;word-wrap: break-word; word-break: break-all;}    
.mui-input-row .div-leftauto{width:110px; display: inline-block;vertical-align: middle;margin-left:5px;/*padding-top: 8px;vertical-align:top;*/}
.mui-input-row.multi-line{height: auto;}

必要注意的是代码:word-wrap: break-word;
word-break:
break-all;

若果不增进这代码的话,当<div
class=”wrap”>中的文字全部是数字恐怕英文的时候将不会并发活动换行。

4858美高梅 ,-webkit-line-clamp

用来限制在三个块成分突显的文本的行数。
为了兑现该意义,它需求组合其余的WebKit属性。常见结合属性:
1.display: -webkit-box; 必须结合的属性
,将指标作为弹性伸缩盒子模型展现 。
2.-webkit-box-orient; 必须结合的属性
,设置或探寻伸缩盒对象的子成分的排列形式 。
3.text-overflow: ellipsis;
能够用来多行文本的图景下,用省略号“…”隐藏超出范围的文本 。

一、应用

浏览器援救:
浏览器 版本 支持 属性
Internet Explorer 6.0+ text-overflow ellipsis|clip
Firefox (Gecko) 7.0+ text-overflow ellipsis|clip
Opera (Presto) 9.* – 10.* -o-text-overflow ellipsis |clip
11.0+ text-overflow ellipsis | clip
Safari | Chrome | WebKit 1.3|1.0| 312.3 text-overflow ellipsis

|clip

经过浏览器补助表我们得以见见,Firefox对text-overflow严重退化于别的浏览器,IE从数年前的陆.0本子就支持了那特性格,而Firefox在IE陆推出之后的漫长岁月里,Firefox经过了4遍大版本号升级都尚未提供支撑,直到Firefox
柒.

到近日结束,Firefox之外的浏览器都帮忙text-overflow
css了,所以开发者只须要针对Firefox 三.x – 6.x做特别处理。

 文字超骑行显示省略号

正如图所示:

4858美高梅 2

代码:

 <div style="overflow: hidden;white-space: nowrap;text-overflow: ellipsis;"> 是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行我是文字随便</div>

那里只援助单行省略号,倘使是多行呢?

    <div style="display: -webkit-box;-webkit-box-orient: vertical;-webkit-line-clamp: 3;overflow: hidden;">
        是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行我是文字
随便几行我是文字随便几行是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行我是文字随便几行
    </div>

运行结果如下:

4858美高梅 3

小编们见到只展现了三行,那是因为自个儿-webkit-line-clamp: 3。那里安装为叁.

因采取了WebKit的CSS扩大属性,该情势适用于WebKit浏览器及活动端;

-webkit-line-clamp用来限制在贰个块成分显示的公文的行数。 为了完结该效率,它要求组合其余的Web基特属性。

如构成如下属性:

  • display: -webkit-box; 必须结合的属性 ,将对象作为弹性伸缩盒子模型展现 。
  • -webkit-box-orient 必须结合的属性 ,设置或探寻伸缩盒对象的子成分的排列格局 。
css 代码:
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;

不过这些天性并不扶助多创作本溢出突显省略号,这里依照使用场景介绍多少个主意来完结这样的效劳。

CSS代码:
.box {
    width: 100px; 
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

除Firefox外的单行文本溢出消除:

对此单行文本溢出大家利用一句话,放在你需求缓解溢出难点的因素上:

overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
-o-text-overflow:ellipsis;

这句话能够消除超过十二分之五的浏览器单行文本溢出。

 斜三角形并带文字效果

作用如下图所示:

4858美高梅 4

HTML如下:

  <div class="font-topright"">待完工</div>
  <div class="triangle-topright mui-badge-orange"></div>
  <div class="font-seal">待料</div>

CSS代码(注意样式的命名,不要搞神马大小写,提议用-或然_连日,统1使用小写):

.font-seal {
    font-size: 12px;z-index: 2;position: absolute;right:14px;top: 35px;    border: 1px solid #F73A3C;
    transform: rotate(45deg);width: 53px;line-height: 20px;text-align: center;color: #F73A3C;font-weight: bold;
}

/**
 * 三角形气泡
 */
.triangle-topright {
    width: 0;height: 0;border-top: 44px solid #FD9D2D;border-left: 2rem solid transparent;
}
.font-topright {
    font-size: 12px;z-index: 2;position: absolute;right: -4px;top: -2px;
    transform: rotate(45deg);-webkit-transform: rotate(45deg);-moz-transform: rotate(45deg);
    -ms-transform: rotate(45deg);-o-transform: rotate(45deg);width: 43px;line-height: 43px;text-align: center;color: #FFFFFF;
}
.mui-badge.mui-badge-orange{background-color:#FC9C2D;color:#FFFFFF;}

WebKit浏览器或挪动端的页面

在WebKit浏览器或移动端(绝一大半是WebKit内核的浏览器)的页面达成相比简单,能够平昔动用WebKit的CSS扩大属性(WebKit是私家属性)-webkit-line-clamp
;注意:那是贰个 不规范的天性(unsupported WebKit
property),它从不出现在
CSS 规范草案中。

HTML代码:
<div class="box">
    美国进口Culturelle康萃乐益生菌30片儿童水果味LGG益生菌咀嚼片
</div>

针对Firefox老版本,做不难号效果

本着Firefox,做不难号效果,近期首要有叁种方案,分别是:

  1. css binding xml
  1. JavaScript截取(此处不做表明,因为能用css为啥要用js)
  2. 简短号遮盖。

 时间轴效果

4858美高梅 5

时光轴设计的难点在于全数的节点都以动态渲染的,最新的节点又和其它节点的体裁不等同,节点的显得地方相比较难控制,还有就是节点之间的连线必须适度的把各类节点连接起来。

终极渲染的HTML代码:

<body class="mui-ios mui-ios-11 mui-ios-11-0">
    <div id="app" class="mui-content" style="background-color: rgb(255, 255, 255);">
        <div class="empty-container" style="display: none;">
            <div class="nodata-info">暂无相关内容</div>
            <div class="nodata-icon">

            </div>
        </div>
        <section id="cd-timeline" class="cd-container" style="">
            <div class="cd-timeline-block">
                <div class="cd-timeline-img cd-picture"></div>
                <div class="cd-timeline-content">
                    <div>用户4,工单结束</div> <div class="cd-date">2018-05-22 14:33:58</div>
                </div>
            </div>
            <div class="cd-timeline-block">
                <div class="cd-timeline-img cd-movie"></div>
                <div class="cd-timeline-content">
                    <div>用户4,工作人员到场签到</div>
                    <div class="cd-date">2018-05-22 14:33:44</div>
                </div>
            </div><div class="cd-timeline-block">
                <div class="cd-timeline-img cd-movie"></div> <div class="cd-timeline-content">
                    <div>用户4,分配工作人员</div>
                    <div class="cd-date">2018-05-22 14:33:34</div>
                </div>
            </div>
            <div class="cd-timeline-block">
                <div class="cd-timeline-img cd-movie"></div>
                <div class="cd-timeline-content"><div>用户4,提交报修单</div> <div class="cd-date">2018-05-21 18:06:44</div></div>
            </div>
        </section>
    </div>
</body>

CSS样式timeline.css

4858美高梅 64858美高梅 7

[v-cloak] {display: none !important;}/*visibility: hidden;*/
/* -------------------------------- 
Primary style
-------------------------------- */
/*html{background-color: #FFFFFF;}*/
.mui-bar{background-color: #449DED;}
.mui-bar-nav .mui-icon {color: #FFFFFF;}
.mui-title {color: #fff;}
*, *:after, *:before {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
img {max-width: 100%;}
/* -------------------------------- 
Modules - reusable parts of our design
-------------------------------- */
.cd-container {
  /* this class is used to give a max-width to the element it is applied to, and center it horizontally when it reaches that max-width */
  width: 100%;max-width: 1170px;margin: 0;
}
.cd-container::after {
  /* clearfix */
  content: '';display: table;clear: both;
}
/* -------------------------------- 
Main components 
-------------------------------- */
#cd-timeline {
  position: relative;padding: 0;margin-top: 0;margin-bottom: 1em;
}
/*#cd-timeline::before {
  content: '';position: absolute;top: 0;left: 18px;
  height: 80%;width: 1px;background: #C3E3FF;top:20px;
}*/
.cd-timeline-block:before{
      content: '';position: absolute;height: 67px;width: 1px;
    background: #C3E3FF;left: 25px;bottom: -28px;
}
.cd-timeline-block:first-child:before{
    top: 28px;
}
.cd-timeline-block:last-child:before{
    height: 0px;
}
#cd-timeline::after {
    height: 0px;
}
@media only screen and (min-width: 1170px) {
  #cd-timeline {
    margin-top: 3em;margin-bottom: 3em;
  }
#cd-timeline::before {
    left: 50%;margin-left: -2px;}
}
.cd-timeline-block {
  position: relative;margin: 2px 0 0 0;
}
.cd-timeline-block:after {
  content: "";display: table;clear: both;
}
.cd-timeline-block:first-child {
  margin-top: 0;
}
.cd-timeline-block:last-child {
  margin-bottom: 0;
}
@media only screen and (min-width: 1170px) {
  .cd-timeline-block {
    margin: 4em 0;
  }
  .cd-timeline-block:first-child {
    margin-top: 0;
  }
  .cd-timeline-block:last-child {
    margin-bottom: 0;
  }
}
.cd-timeline-img {
  position: absolute;top: 0;left: 0;width: 16px;height: 16px;border-radius: 50%;
  margin-top: 10px;box-shadow: 0 0 0 5px #DDEEFE;/*inset 0 2px 0 #60B2FB, 0 3px 0 5px #DDEEFE;*/
}
.cd-timeline-img img {
  display: block;width: 24px;height: 24px;
  position: relative;left: 50%;top: 50%;margin-left: -12px;margin-top: -12px;
}
.cd-timeline-img.cd-picture {
  background: #60B3FC; margin-left: 17px;margin-top: 25px;
}
.cd-timeline-img.cd-movie {
  background: #60B2FB; left: 21px;width: 10px;height: 10px;box-shadow:none;top:16px;
}
.cd-timeline-img.cd-location {
  background: #f0ca45;
}
@media only screen and (min-width: 1170px) {
  .cd-timeline-img {
    width: 60px;height: 60px;left: 50%;margin-left: -30px;
    /* Force Hardware Acceleration in WebKit */
    -webkit-transform: translateZ(0);-webkit-backface-visibility: hidden;
  }
  .cssanimations .cd-timeline-img.is-hidden {
    visibility: hidden;
  }
  .cssanimations .cd-timeline-img.bounce-in {
    visibility: visible;-webkit-animation: cd-bounce-1 0.6s;
    -moz-animation: cd-bounce-1 0.6s; animation: cd-bounce-1 0.6s;
  }
}
.cd-timeline-content {
  position: relative;margin-left: 50px;background: white;
  border-radius: 0;padding: 0.4em;box-shadow: 0 1px 0 #d7e4ed;
}
.cd-timeline-content:after {
  content: "";display: table;clear: both;
}
.cd-timeline-content h2 {
  color: #303e49;
}
.cd-timeline-content p, .cd-timeline-content .cd-read-more, .cd-timeline-content .cd-date {
  font-size: 13px;font-size: 0.8125rem;
}
.cd-timeline-content .cd-read-more, .cd-timeline-content .cd-date {
  display: inline-block;
}
.cd-timeline-content p {
  margin: 1em 0;line-height: 1.6;
}
.cd-timeline-content .cd-read-more {
  float: right;padding: .8em 1em;
  background: #acb7c0;color: white;border-radius: 0.25em;
}
.no-touch .cd-timeline-content .cd-read-more:hover {
  background-color: #bac4cb;  
}
a.cd-read-more:hover{text-decoration:none; background-color: #424242;  }
.cd-timeline-content .cd-date {
  float: left;padding: .4em 0;color: #A3A3A3;
}
.cd-timeline-content::before {
  content: '';position: absolute;top: 9px;right: 100%;height: 0;width: 0;
  border: 7px solid transparent;border-right: 7px solid white;
}
@media only screen and (min-width: 768px) {
  .cd-timeline-content h2 {
    font-size: 20px;font-size: 1.25rem;
  }
  .cd-timeline-content p {
    font-size: 16px;font-size: 1rem;
  }
  .cd-timeline-content .cd-read-more, .cd-timeline-content .cd-date {
    font-size: 14px;font-size: 0.875rem;
  }
}
@media only screen and (min-width: 1170px) {
  .cd-timeline-content {
    margin-left: 0;padding: 1.6em; width: 45%;
  }
  .cd-timeline-content::before {
    top: 24px;left: 100%;border-color: transparent;border-left-color: white;
  }
  .cd-timeline-content .cd-read-more {
    float: left;
  }
  .cd-timeline-content .cd-date {
    position: absolute;width: 100%;left: 122%;top: 6px;font-size: 16px;font-size: 1rem;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content {
    float: right;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content::before {
    top: 24px;left: auto;right: 100%;border-color: transparent;border-right-color: white;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content .cd-read-more {
    float: right;
  }
  .cd-timeline-block:nth-child(even) .cd-timeline-content .cd-date {
    left: auto;right: 122%;text-align: right;
  }
  .cssanimations .cd-timeline-content.is-hidden {
    visibility: hidden;
  }
  .cssanimations .cd-timeline-content.bounce-in {
    visibility: visible;-webkit-animation: cd-bounce-2 0.6s;
    -moz-animation: cd-bounce-2 0.6s;animation: cd-bounce-2 0.6s;
  }
}
@media only screen and (min-width: 1170px) {
  /* inverse bounce effect on even content blocks */
  .cssanimations .cd-timeline-block:nth-child(even) .cd-timeline-content.bounce-in {
    -webkit-animation: cd-bounce-2-inverse 0.6s;
    -moz-animation: cd-bounce-2-inverse 0.6s; animation: cd-bounce-2-inverse 0.6s;
  }
}
.cd-timeline-content div{height: 21px;line-height: 21px;}
.cd-timeline-content div:first-child{
    color: #6DB6FE;font-size: 14px;line-height: 25px;
}
.cd-timeline-content div:last-child{line-height: 18px;}
/*为空*/
.empty-container{text-align:center;padding: 30% 0;background-color:#F5F5F5;overflow:hidden;height: 100%;position: fixed;width: 100%;}
.nodata-info{color:#C7C3C2;}
.nodata-icon{color:#C7C3C2;margin-top:25px;}
.nodata-icon .mui-icon{font-size:120px;}

View Code

小编那边原本是使用了vue.js,理论上支持N个时间节点,原代码如下:

<div id="app" class="mui-content" style="background-color: #FFFFFF;">
            <div v-show="isEmptyData" class="empty-container" v-cloak>
                <div class="nodata-info">暂无相关内容</div>
                <div class="nodata-icon"></div>
            </div>
            <section v-show="list.length>0" id="cd-timeline" class="cd-container" v-cloak>
                <div v-for="(item,index) in list" class="cd-timeline-block">
                    <div class="cd-timeline-img" v-bind:class="[index==0?'cd-picture':'cd-movie']"></div>
                    <div class="cd-timeline-content">
                        <div v-text="item.text"></div>
                        <div class="cd-date" v-text="item.t"></div>
                    </div>
                </div>
            </section>
        </div>

js代码:

            var vm = new Vue({
                el: '#app',
                data: {
                    isEmptyData:false,
                    list: []
                },
                mounted: function () {
                    mui.init();
                    this.list = [{ "text": "用户4,工单结束", "t": "2018-05-22 14:33:58" }, { "text": "用户4,工作人员到场签到", "t": "2018-05-22 14:33:44" }, 
{ "text": "用户4,分配工作人员", "t": "2018-05-22 14:33:34" }, { "text": "用户4,提交报修单", "t": "2018-05-21 18:06:44" }];
}});

 MUI是尤其轻量级的活动前端框架,而vue.js也是极简而雅致的mvvm框架,所以他们两合在1起使用实在是太便宜了,可是他俩两壹起采取的同时会存在重重坑,若要避开这么些坑,你须要明白MUI和vue.js他们的运转机制,其实也正是Dom操作、mui的生命周期同数据驱动、vue.js生命周期它们中间差别。

webstorm 2018激活破解方法大全

-webkit-line-clamp

用来限制在一个块成分显示的文书的行数。
为了贯彻该意义,它必要结合别的的WebKit属性。常见结合属性:
1.display: -webkit-box; 必须结合的属性
,将对象作为弹性伸缩盒子模型展现 。
2.-webkit-box-orient; 必须结合的属性
,设置或探寻伸缩盒对象的子成分的排列格局 。
3.text-overflow: ellipsis;
能够用来多行文本的境况下,用省略号“…”隐藏超出范围的文本 。

效果:

美国进口Culturelle康萃乐
益生菌30片儿童水果味LGG...

 

css binding xml

那是鬼子提供的一种办法,使用Firefox的村办属性调用三个XML文件(ellipsis.xml),能够使Firefox火狐浏览器下文字溢出后以省略号的格局显得。

ellipsis.xml的始末如下:

<bindings xmlns="http://www.mozilla.org/xbl" xmlns:xbl="http://www.mozilla.org/xbl" xmlns:xul="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
    <binding id="ellipsis">
        <content>
            <xul:description crop="end" xbl:inherits="value=xbl:text">
                 <children/>
            </xul:description>
        </content>
    </binding>
</bindings>

把ellipsis.xml另存为到本地你的css文件存放的地点,然后就是调用:

-moz-binding:url(‘ellipsis.xml#ellipsis’);

跟css样式写法1致,再组成地方的css样式,就足以完结全数主流浏览器下的单行文字溢出用简易号表示了。css表示如下:

overflow: hidden;
white-space: nowrap;
text-overflow: ellipsis;
-o-text-overflow:ellipsis;
-moz-binding:url('ellipsis.xml#ellipsis');

留神:此XML文件一般不支持发展路径的造访,也不帮衬相对路径的造访。也正是说此XML文件需求放在调用文件(css文件,或HTML文件)的同目录下或下一流目录下,不可能升高访问。所以为了麻烦直接存到调用文件的统超级目录就行了

css 代码:
overflow : hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;

这一个天性比较合适WebKit浏览器或移动端(绝当先1贰分之5是Web基特内核的)浏览器。

二、理解

留意:-webkit-line-clamp是webkit的私人住房属性,是1个不僧不俗的习性(unsupported WebKit property),它并未有出现在 CSS
规范草案中。

        -webkit-line-clamp用来界定在3个块成分展现的文件的行数。
为了落到实处该意义,它须求组合别的的WebKit属性。常见结合属性:

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

        -webkit-box-orient 必须结合的属性
,设置或探寻伸缩盒对象的子成分的排列方式 。

 

总结号遮盖

那种办法有点老的掉牙,因为自201③年从此全部浏览器都已经辅助text-overflow:ellipsis;方法

就此那里只是附上代码我们看看得了

<h3>省略号遮盖法</h3>
<div class="text_overflow_margin" >
    <div class="margin_con" >这是一段比较长的文字,用来测试是否文字溢出时会用省略号显示。</div>
    <div class="margin_ellipsis" >…</div>
</div>
<style>
    .text_overflow_margin{
        width: 24em; height: 20px; overflow:hidden; zoom:1; background: #333;
    }
    .text_overflow_margin .margin_con{
        height: 20px; margin-right: 1em; background: #f00;
    }
    .text_overflow_margin .margin_ellipsis{
        width: 1em; height: 20px; float:right; margin-top: -20px;
    }
</style>

跨浏览器包容的方案

正如可靠不难的做法正是安装相对固定的器皿高度,用含有省略号(…)的要素模拟实现;

三、兼容性

那些属性 如今仅援救webkit浏览器,相比较合适WebKit浏览器或移动端(移动端绝大多数是Web基特内核的浏览器)

跨浏览器包容的方案

A:比较可相信简单的做法就是设置相对固化的器皿中度,用带有省略号(…)的要素模拟完结

4858美高梅 8p {
  position: relative;   line-height: 1.4em;   height: 4.2em;
  overflow: hidden; } p::after {   content: “…”;   font-weight:
bold;   position: absolute;   bottom: 0;   right: 0;   padding:
0 20px 1px 45px;
  backgroundnull:url()
repeat-y; } View Code 

那边注意几点:

height中度正好是line-height的三倍;

停止的省略好用了半透明的png做了减淡的效益,或然设置背景颜色;

IE陆-七不展现content内容,所以要包容IE陆-7得以是在剧情中参预三个标签,比如用<span
class=”line-clamp”>…</span>去模拟;

要支持IE8,需要将::after替换成:after;

 

B:Javascript (插件)方案    

用js也能够根据地方的思绪去模拟,完毕也极粗略

1.clamp.js   使用也分外简单:

var module = document.getElementById("clamp-this-module");

$clamp(module, {clamp: 2});

 

2.jQuery插件-jQuery.dotdotdot   本条动用起来也很有利:

$(function(){
  $("wrapper").dotdotdot({
    // configuration goes here
  });
});

多创作本溢出省略号

css 代码:
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:url(http://css88.b0.upaiyun.com/css88/2014/09/ellipsis_bg.png) repeat-y;
}

那里注意几点:
一.height中度真好是line-height的三倍;
二.了却的省略好用了半晶莹剔透的png做了减淡的效用,只怕设置背景颜色;
3.IE6-七不显得content内容,所以要包容IE6-七足以是在内容中进入三个标签,比如用<span
class=”line-clamp”>…</span>去模拟;
4.要支持IE8,需要将::after替换成:after;

延长:单行文本溢出显示省略号…代码

  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap

 

 

多行文字溢出…,webkitlineclamp 一、应用 CSS代码: .box { width: 100px;
display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient:
vertical;…

不匹配的WebKit内核新版属性

有时候大家须要在多行文本前边添加1个省略号,怎么着添加呢?

display: -webkit-box;
-webkit-box-orient: vertical;
-webkit-line-clamp: 3;
overflow: hidden;

说明:

  1. -webkit-line-clamp用来限制在2个块成分呈现的文书的行数。
    为了兑现该功用,它供给组合别的的WebKit属性。
  2. display: -webkit-box; 必须结合的属性
    ,将对象作为弹性伸缩盒子模型突显 。
  3. -webkit-box-orient 必须结合的属性
    ,设置或探寻伸缩盒对象的子成分的排列情势 。

适用范围:因接纳了WebKit的CSS增添属性,该措施适用于WebKit浏览器及活动端;所以其包容性不太好

<p class="article_synopsis">
        我们时常对城市中的建筑过目即忘,甚至你不会觉得城市与城市之间有什么不同。因为这些钢筋混泥土建筑的空间里,没有与我们内心与之呼应的东西。这些东西是一个民族几千年里凝练下来的一种审美,流淌在我们的血液里。
</p>
<style>
    .article_synopsis{
        display: -webkit-box; text-overflow: ellipsis; text-indent: 2em;
        overflow : hidden; -webkit-line-clamp: 5; -webkit-box-orient: vertical;
        height: 90px; width: 170px; font-size: 12px;
    }
</style>

JavaScript 方案

用js也足以根据上边的笔触去模拟

  1. 多行文本超出省略号包容IE8 :好处是足以自行判断文本或长或短。

相当的写法

我们为了协作思量能够动用伪类来完结平等的功力

p{position: relative; line-height: 20px; max-height: 40px;overflow: hidden;}
p::after{content: "..."; position: absolute; bottom: 0; right: 0; }

总体代码达成:

<p class="synopsis">
        我们时常对城市中的建筑过目即忘,甚至你不会觉得城市与城市之间有什么不同。因为这些钢筋混泥土建筑的空间里,没有与我们内心与之呼应的东西。这些东西是一个民族几千年里凝练下来的一种审美,流淌在我们的血液里。
</p>
<style>
    .synopsis{
        position: relative; line-height: 20px; overflow: hidden;
        height: 80px; width: 170px; font-size: 12px;
    }
    .synopsis::after{
        content: "..."; position: absolute; bottom: 0; right: 0;
        line-height: 20px; background: #fff; width: 14px;
    }
</style>

说明:

  1. 安装line-height属性,防止过量的文字表露部分。
  2. 给p::after添加定位、颜色、行高及增加率可防止文字只显示一半。
  3. 出于ie陆-7不显得content内容,所以要添加标签包容ie陆-7(如:<span>…<span/>);包容ie8须求将::after替换到:after。

适用范围:该方法适用范围广,但文字未超骑行的情形下也会并发省略号,可整合js优化该办法。

有关JavaScript
方案可以去探视Clamp.js和jQuery插件-jQuery.dotdotdot

小结:

迄今我们常用的css溢出变为省略号的点子基本竣事了

提醒:后面还有卓绝敬请期待,请我们关切自笔者的CSDN博文:侬姝沁儿,或然本人的简书专题:web前端。如有意见能够进行业评比价,每一条评论作者都会认真对照。

JS代码:
$(".video-list-p").each(function(i){
    var divH = $(this).height();
    var $p = $("span", $(this)).eq(0);
    while ($p.outerHeight() > divH) {
        $p.text($p.text().replace(/(\s)*([a-zA-Z0-9]+|\W)(\.\.\.)?$/, "..."));
    };
});

2.插件:
Clamp.js
下载及文书档案地址:https://github.com/josephschmitt/Clamp.js

js 代码:
var module = document.getElementById("clamp-this-module");
$clamp(module, {clamp: 3});

dome地址:https://codepen.io/feiwen8772/pen/AckqK

jQuery.dotdotdot
下载及详细文书档案地址:https://github.com/BeSite/jQuery.dotdotdot或http://dotdotdot.frebsite.nl/

js 代码:
$(document).ready(function() {
    $("#wrapper").dotdotdot({
        //  configuration goes here
    });
});

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图
Copyright @ 2010-2019 美高梅手机版4858 版权所有