关于CSS3的变形、过渡、动画、关联属性

2017/03/09 · CSS ·
关联,
动画,
变形,
过渡

原文出处:
牧羊人_cily   

如何用 CSS 实现多行文本的省略号显示

2017/03/31 · CSS ·
CSS

本文作者: 伯乐在线 –
欲休
。未经作者许可,禁止转载!
欢迎加入伯乐在线 专栏作者。

本文翻译自CSS Ellipsis: How to Manage Multi-Line Ellipsis in Pure
CSS,文中某些部分有些许改动,并添加译者的一些感想,请各位读者谅解。

合理的截断多行文本是件不容易的事情,我们通常采用几种方法解决:

  • overflow: hidden直接隐藏多余的文本
  • text-overflow: ellipsis只适用于单行文本的处理
  • 各种比较脆弱的javascript实现。之所以说这种实现比较脆弱是由于需要文本长度的变化时刻得到回流(relayout)后的布局信息,如宽度

英文原文写作时间是2012.9.18号,比较有意义的一天。不过作者忽略了WebKit提供的一个扩展属性-webkit-line-clamp,它并不是CSS规范中的属性。利用该属性实现多行文本的省略号显示需要配合其他三个属性:display: -webkit-box-webkit-box-orienttext-overflow: ellipsis;。其中,-webkit-line-clamp设置块元素包含的文本行数;display: -webkit-box设置块元素的布局为伸缩布局;-webkit-box-orient设置伸缩项的布局方向;text-overflow: ellipsis;则表示超出盒子的部分使用省略号表示。

不过本文将要介绍的方法是采用CSS规范中的属性,并结合特殊的实现技巧完成的。这意味着在实现CSS2.1规范的浏览器中都是可以兼容的,不将仅仅是纯粹的移动端领域,在传统的PC浏览器(你们懂得我指的是哪些浏览器)中仍是可行的。好吧,让我们一起见识下。

有趣的CSS题目(2): 从条纹边框的实现谈盒子模型

2016/09/29 · CSS ·
CSS

本文作者: 伯乐在线 –
chokcoco
。未经作者许可,禁止转载!
欢迎加入伯乐在线 专栏作者。

开本系列,讨论一些有趣的 CSS
题目,抛开实用性而言,一些题目为了拓宽一下解决问题的思路,此外,涉及一些容易忽视的
CSS 细节。

解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉到生僻的
CSS 属性,赶紧去补习一下吧。

不断更新,不断更新,不断更新,重要的事情说三遍。

谈谈一些有趣的CSS题目(1):
左边竖条的实现方法

所有题目汇总在我的 Github 。

一、变形

transform:可以对元素对象进行旋转rotate、缩放scale、移动translate、倾斜skew、矩阵变形matrix。
示例:

CSS

transform: rotate(90deg) scale(1.5,0.8) translate(100px,50px)
skew(45deg,45deg); /*矩阵变形*/
matrix(<number>,<number>,<number>,<number>,<number>,<number>);
/*透视*/ perspective(length);

1
2
3
4
5
transform: rotate(90deg) scale(1.5,0.8) translate(100px,50px) skew(45deg,45deg);
/*矩阵变形*/
matrix(<number>,<number>,<number>,<number>,<number>,<number>);
/*透视*/
perspective(length);

transition:过度属性
transition:过度效果的css属性名 过度效果时长 速度效果的速度曲线
过度效果开始时间;

CSS

transition: property duration timing-function delay; /*示例*/
transition:1s ease all; -webkit-tansition:1s ease all;
-moz-transition:1s ease all; -o-transition:1s ease all;

1
2
3
4
5
6
transition: property duration timing-function delay;
/*示例*/
transition:1s ease all;
-webkit-tansition:1s ease all;
-moz-transition:1s ease all;
-o-transition:1s ease all;

rotate():二维空间旋转元素。
若元素设置了perspective值,可用rotate3d()实现三维空间内旋转。

CSS

rotateX(angele)/*相当于rotate3d(1,0,0,angle)指定在三维空间内的X轴旋转*/
rotateY(angele)/*相当于rotate3d(0,1,0,angle)指定在三维空间内的Y轴旋转*/
rotateZ(angele)/*相当于rotate3d(0,0,1,angle)指定在三维空间内的Z轴旋转*/

1
2
3
rotateX(angele)/*相当于rotate3d(1,0,0,angle)指定在三维空间内的X轴旋转*/
rotateY(angele)/*相当于rotate3d(0,1,0,angle)指定在三维空间内的Y轴旋转*/
rotateZ(angele)/*相当于rotate3d(0,0,1,angle)指定在三维空间内的Z轴旋转*/

scale()

CSS

scaleX(<number>)/*只在X轴(水平方向)缩放元素*/
scaleY(<number>)/*只在Y轴(垂直方向)缩放*/
scaleZ(<number>)/*只在Z轴缩放,前提:元素设定透视值*/

1
2
3
scaleX(<number>)/*只在X轴(水平方向)缩放元素*/
scaleY(<number>)/*只在Y轴(垂直方向)缩放*/
scaleZ(<number>)/*只在Z轴缩放,前提:元素设定透视值*/

translate([,]):移动,是位移量。

CSS

translateX(<translation-value>);/*只在X轴(水平方向)移动*/
translateY(<translation-value>);/*只在Y轴(垂直方向)移动*/
translateZ(<translation-value>);/*只在Z轴移动,前提:元素设置透视值*/

1
2
3
translateX(<translation-value>);/*只在X轴(水平方向)移动*/
translateY(<translation-value>);/*只在Y轴(垂直方向)移动*/
translateZ(<translation-value>);/*只在Z轴移动,前提:元素设置透视值*/

skew()澳门微尼斯人手机版,:倾斜

CSS

skewX(<angle>);/*只在X轴(水平)倾斜*/
skewY(<angle>);/*只在Y轴(垂直)倾斜*/

1
2
skewX(<angle>);/*只在X轴(水平)倾斜*/
skewY(<angle>);/*只在Y轴(垂直)倾斜*/

matrix(a,c,e,b,d,f):矩阵变形,c、e的值用正弦或余弦值表示。
a:表示scaleX(); X轴缩放
c:skewY(); Y轴倾斜
e:skewX(); X轴倾斜
b:scaleY(); Y轴缩放
d:translateX() X轴移动
f:translateY() Y轴移动

CSS

transform:matrix(<number>,<number>,<number>,<number>,<number>,<number>);

1
transform:matrix(<number>,<number>,<number>,<number>,<number>,<number>);

perspective():透视

CSS

.wrap{ perspective:1000px; } .wrap .child{
transform:perspective(1000px); }

1
2
3
4
5
6
.wrap{
    perspective:1000px;
}
.wrap .child{
    transform:perspective(1000px);
}

CSS实现多行文本溢出的省略号显示

我们把实现的细节划分为7个步骤,在这个实现过程中最简单的就是截断文本,而最难的部分则是让一个元素处在其父包含块溢出时的右下方,并且当父元素未溢出时该元素消失不可见。为了去难避易,我们先从比较简单的地方开始–当父包含框比较小时,将子元素布局到父包含框的右下角。

2、类似下面这个图形,只使用一个标签,可以有多少种实现方式:

澳门微尼斯人手机版 1

假设我们的单标签为 div:

XHTML

<div></div>

1
<div></div>

定义如下通用 CSS:

CSS

div{ position:relative; width: 180px; height: 180px; }

1
2
3
4
5
div{
    position:relative;
    width: 180px;
    height: 180px;
}

这一题主要考查的是盒子模型 Box Model 与
背景 background 的关系,以及使用 background-clip 改变背景的填充方式。

background 在 Box Model 中,他是布满整个元素的盒子区域的,并不是从 padding 内部开始(也就是说从
border
就开始啦),只不过实线边框(solid)部分遮住了部分 background ,所以我们使用虚线边框(dashed)就可以看到背景色是从 border 内部开始的。

我们给 div 添加如下样式:

CSS

div{ background:#9c27b0; border:20px dashed #2196f3; }

1
2
3
4
div{
    background:#9c27b0;
    border:20px dashed #2196f3;
}

结果如下:
澳门微尼斯人手机版 2

但有一点需要注意,background-color 是从元素的边框左上角起到右下角止,而 background-image 却不一样,他是从 padding 边缘的左上角起而到 border 的右下角边缘止。

background image 的绘制中有两个因素决定了绘图区域:

  • background positioning
    area。
    background-origin 属性决定了这个相对定位位置,默认为 padding-box。所以默认的背景图片绘制是从
    padding box 的左上顶点开始的。
  • background painting
    area。
    background-clip 属性决定了绘制区间,默认为 border-box。所以在background-repeat: repeat 的情况下:

The image is repeated in this direction as often as needed to cover
the background painting area.

嗯,什么意思呢,你可以戳进这个 demo 看看,正常情况下的背景图填充如下:

澳门微尼斯人手机版 3

当然,这个填充规则是可以通过 background-clip 改变的。

background-clip 设置元素的背景(背景图片或颜色)是否延伸到边框下面。

语法:

CSS

{ background-clip: border-box; // 背景延伸到边框外沿(但是在边框之下)
background-clip: padding-box; //
边框下面没有背景,即背景延伸到内边距外沿。 background-clip: content-box;
// 背景裁剪到内容区 (content-box) 外沿。 }

1
2
3
4
5
{
    background-clip: border-box;  // 背景延伸到边框外沿(但是在边框之下)
    background-clip: padding-box; // 边框下面没有背景,即背景延伸到内边距外沿。
    background-clip: content-box; // 背景裁剪到内容区 (content-box) 外沿。
}

XHTML

<!– 填充与background-clip属性有关 –> <!–
背景色的填充规则,默认为 border-box 从盒子最左上角到最右下角 –>
<div class=”bgColor”></div> <div class=”bgColor
contentBox”></div> <div class=”bgColor
paddingBox”></div> <!– 背景图的填充规则,默认为 border-box
从盒子的左上角padding到最右下角 –> <div
class=”bgImg”></div> <div class=”bgImg
contentBox”></div> <div class=”bgImg
paddingBox”></div>

1
2
3
4
5
6
7
8
9
10
11
12
<!– 填充与background-clip属性有关 –>
<!– 背景色的填充规则,默认为 border-box
            从盒子最左上角到最右下角 –>
<div class="bgColor"></div>
<div class="bgColor contentBox"></div>
<div class="bgColor paddingBox"></div>
 
<!– 背景图的填充规则,默认为 border-box
            从盒子的左上角padding到最右下角 –>
<div class="bgImg"></div>
<div class="bgImg contentBox"></div>
<div class="bgImg paddingBox"></div>

CSS

div{ width:150px; height:150px; margin:50px 10px;; border:20px dashed
rgba(0, 0, 0, 0.5); float:left; padding:10px; // background-size:cover;
} .bgColor{ background-color:#ff7300; // background-clip:border-box; }
.bgImg{ background-color:#ff7300;
background-image:url(”);
background-repeat:no-repeat; // background-clip:border-box; }
.contentBox{ background-clip:content-box; } .paddingBox{
background-clip:padding-box; }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
div{
    width:150px;
    height:150px;
    margin:50px 10px;;
    border:20px dashed rgba(0, 0, 0, 0.5);
    float:left;
    padding:10px;
    // background-size:cover;
}
.bgColor{
    background-color:#ff7300;
    // background-clip:border-box;
}
.bgImg{    
    background-color:#ff7300;
    background-image:url(‘http://www.qq1234.org/uploads/allimg/150602/8_150602171754_2.jpg’);
    background-repeat:no-repeat;
    // background-clip:border-box;
}
.contentBox{
    background-clip:content-box;
}
.paddingBox{
    background-clip:padding-box;
}

See the Pen CssBackground by
Chokcoco (@Chokcoco) on
CodePen.

继续说回本题,接下来,只需要将中间部分填充为白色即可,这个用伪元素可以轻松完成,所以,其中一个方法如下:

CSS

div{ background:#9c27b0; border:20px dashed #2196f3; } div::after{
content:””; position:absolute; top:0; left:0; bottom:0; right:0;
background:#fff; }

1
2
3
4
5
6
7
8
9
10
11
12
13
div{
    background:#9c27b0;
    border:20px dashed #2196f3;
}
div::after{
    content:"";
    position:absolute;
    top:0;
    left:0;
    bottom:0;
    right:0;
    background:#fff;
}

二、过渡

transition-property:过度的属性

CSS

transition-property:all;/*针对所有元素都有过度效果*/
transition-property:none;/*没有元素有过度效果*/
transition-property:ident;/*指定css属性有过度效果,例如width*/

1
2
3
transition-property:all;/*针对所有元素都有过度效果*/
transition-property:none;/*没有元素有过度效果*/
transition-property:ident;/*指定css属性有过度效果,例如width*/

transition-duration:过度时间
transition-delay:延迟时间,为负数时,过度动作会从该时间点开始显示,之前的动作会被截断。
transition-timing-function:过度效果,默认ease。

JavaScript

transition-timing-function:ease;/*缓解效果,等同于cubic-bezier(0.25,0.1,0.25,1.0)函数,既立方贝塞尔*/
transition-timing-function:linear;/*线性效果,等同于cubic-bezier(0.0,0.0,1.0,1.0)函数*/
transition-timing-function:ease-in;/*渐显效果,等同于cubic-bezier(0.42,0,1.0,1.0)函数*/
transition-timing-function:ease-out;/*渐隐效果,等同于cubic-bezier(0,0,0.58,1.0)函数*/
transition-timing-function:ease-in-out;/*渐显渐隐效果,等同于cubic-bezier(0.42,0,0.58,1.0)函数*/
transition-timing-function:cubic-bezier;/*特殊的立方贝塞尔曲线效果*/

1
2
3
4
5
6
transition-timing-function:ease;/*缓解效果,等同于cubic-bezier(0.25,0.1,0.25,1.0)函数,既立方贝塞尔*/
transition-timing-function:linear;/*线性效果,等同于cubic-bezier(0.0,0.0,1.0,1.0)函数*/
transition-timing-function:ease-in;/*渐显效果,等同于cubic-bezier(0.42,0,1.0,1.0)函数*/
transition-timing-function:ease-out;/*渐隐效果,等同于cubic-bezier(0,0,0.58,1.0)函数*/
transition-timing-function:ease-in-out;/*渐显渐隐效果,等同于cubic-bezier(0.42,0,0.58,1.0)函数*/
transition-timing-function:cubic-bezier;/*特殊的立方贝塞尔曲线效果*/

1st 引子

澳门微尼斯人手机版 4
澳门微尼斯人手机版 5
其实这个实现完全利用了元素浮动的基本规则。在这里不详细讲解CSS2.1规范中的几种情形,不明白的读者自行查阅。这段代码实现很简单,就是三个子元素和包含块的高度及浮动设置:

JavaScript

<div class=”wrap”> <div
class=”prop”>1.prop<br>float:left</div> <div
class=”main”>2.main<br>float:right<br>Fairly short
text</div> <div
class=”end”>3.end<br>float:right</div> </div> .wrap
{ width: 400px; height: 200px; margin: 20px 20px 50px; border: 5px solid
#AAA; line-height: 25px; } .prop { float: left; width: 100px; height:
200px; background: #FAF; } .main { float: right; width: 300px;
background: #AFF; } .end { float: right; width: 100px; background:
#FFA; }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
<div class="wrap">
  <div class="prop">1.prop<br>float:left</div>
  <div class="main">2.main<br>float:right<br>Fairly short text</div>
  <div class="end">3.end<br>float:right</div>
</div>
 
.wrap {
  width: 400px; height: 200px;
    margin: 20px 20px 50px;
    border: 5px solid #AAA;
    line-height: 25px;
}
 
.prop {
    float: left;
    width: 100px; height: 200px;
    background: #FAF; }
.main {
    float: right;
    width: 300px;
    background: #AFF; }
.end {
    float: right;
    width: 100px;
    background: #FFA; }

三、动画

animation-name:动画名称,必须与规则@keyframes配合使用,因为动画名称由@keyframes定义,如果提供多个属性值用逗号隔开。
@keyframes相当于一个命名空间,后面跟一个名词,如果在class中的animation-name定义了与之对应的name就可以执行动画。定义动画时可直接使用关键字from和to,从一种状态过度到另一种状态。

CSS

.animation_name{ left:0; top:100px; position: absolute;
-webkit-animation: 0.5s 0.5s ease infinite alternate; -moz-animation:
0.5s 0.5s ease infinite alternate; -webkit-animation-name:demo;
-moz-animation-name:demo; } @-webkit-keyframes demo{ from{left:0;}
to{left:400px;} } @-webkit-keyframes demo1{ 0%{left:0;} 50%{left:200px;}
100%{left:400px;} }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
.animation_name{
    left:0;
    top:100px;
    position: absolute;
    -webkit-animation: 0.5s 0.5s ease infinite alternate;
    -moz-animation: 0.5s 0.5s ease infinite alternate;
    -webkit-animation-name:demo;
    -moz-animation-name:demo;
}
@-webkit-keyframes demo{
    from{left:0;}
    to{left:400px;}
}
@-webkit-keyframes demo1{
    0%{left:0;}
    50%{left:200px;}
    100%{left:400px;}
}

animation-duration:动画时间

animation-timing-function:播放方式,取值如下:
ease:缓解效果,等同于cubic-bezier(0.25,0.1,0.25,1.0)函数,既立方贝塞尔。
linear:线性效果
ease-in:渐显效果
ease-out:渐隐效果
ease-in-out:渐显渐隐效果
step-start:马上跳转到动画结束状态
step-end:保持动画开始状态,到动画执行时间结束,马上跳转到动画结束状态
step([,[start |
end]]?):第一个参数number为指定的间隔数,即把动画分为n步阶段性显示,第二个参数默认为end,设置最后一步状态,start为结束时的状态,end为开始时的状态,若设置与animation-fill-mode的效果冲突,以animation-fill-mode的设置为动画结束状态。
cubic-bezier(,,,):特殊的立方赛贝尔曲线效果

animation-delay:开始播放时间

animation-iteration-count:播放次数,取值为infinite时表示无限循环播放

animation-direction:播放方向,取值为:
normal:正常方向
reverse:动画反向运行,方向始终与normal相仿
alternate:动画会循环正反交替运动

animation-fill-mode:播放后的状态,取值:
none:默认值,不设置
forwards:结束后保持动画结束的状态
backwards:结束后返回动画开始时状态
both:结束后可遵循forwards和backwards两个规则
animation-play-state:检索或设置对象动画的状态,取值:
running:默认,运动
paused:暂停

四、关联属性

transform-origin:变形原点,transform的参照点,默认为元素的中心点。有两个参数,参数一为横坐标,参数二为纵坐标。
percentage:用百分比指定坐标值,可负
length:用长度指定坐标值,可负
left center right:水平方向取值
top center bottom:垂直方向取值

perspective-prigin:透视原点,定义在X轴和Y轴的3D元素,允许改变3D元素的底部位置,定义该属性时,它是一个元素的子元素,透视图,而不是元素本身。
注意:使用该属性必须和perspective属性一起用,只影响3D转换的元素。
取值:percentage、length、left、center、right、top、center、bottom

backface-visibility:隐藏内容的背面,默认情况下背面可见,反转后变换的内容仍然可见,当backface-visibility设置hidden时,旋转后内容将隐藏,旋转后正面将不再可见。
取值:visible、hidden
transform-style:3D呈现,设置内嵌的元素在3D空间如何呈现,有两个值:
flat:所有子元素在2D平面呈现
preserve-3d:保留3D空间

2 赞 2 收藏
评论

澳门微尼斯人手机版 6

2nd 模拟场景

我们通过创建一个子元素来替代将要显示的省略号,当文本溢出的情形下该元素显示在正确的位置上。在接下来的实现中,我们创建了一个realend元素,并利用上一节end元素浮动后的位置来实现realend元素的定位。

JavaScript

<div class=”wrap”> <div class=”prop”> 1.prop<br>
float:right</div> <div class=”main”> 2.main<br>
float:left<br> Fairly short text</div> <div
class=”end”> <div class=”realend”> 4.realend<br>
position:absolute</div> 3.end<br>float:right </div>
</div> .end { float: right; position: relative; width: 100px;
background: #FFA; } .realend { position: absolute; width: 100%; top:
-50px; left: 300px; background: #FAA; font-size: 13px; }

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
<div class="wrap">
  <div class="prop">
   1.prop<br>
   float:right</div>
  <div class="main">
   2.main<br>
   float:left<br>
   Fairly short text</div>
  <div class="end">
   <div class="realend">
     4.realend<br>
     position:absolute</div>
  3.end<br>float:right
  </div>
</div>
 
.end {
    float: right; position: relative;
    width: 100px;
    background: #FFA; }
.realend {
    position: absolute;
    width: 100%;
    top: -50px;
    left: 300px;
    background: #FAA; font-size: 13px; }

这一步中,我们主要关心的是realend元素的定位,基于浮动后的end元素设置偏移量,当end元素浮动到第一节第二章图的位置时(即在prop元素的下方),此时realend元素正好处在end元素的上方50px,右侧300px-100px=200px处,而该位置正是父包含框wrap元素的右下角,此时正是我们期待的结果:
澳门微尼斯人手机版 7

若父元素并没有溢出,那么realend元素会出现在其右侧
澳门微尼斯人手机版 8
这种情况解决很简单,请看下文之第七节,此处仅作实例说明。

发表评论

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