美文网首页
css3-转换/变形(transform)、过渡(transit

css3-转换/变形(transform)、过渡(transit

作者: Knight52033 | 来源:发表于2019-08-29 10:57 被阅读0次

转换(transform)

2D转换

  • translate():

    translate.png
  • rotate():

    rotate.png
  • scale():

    scale.png
  • skew():

    skew.png skew.png
  • matrix():
    matrix( a, b, c, d, e, f );
    a 水平缩放
    b 水平倾斜
    c 垂直倾斜
    d 垂直缩放
    e 水平移动
    f 垂直移动

    matrix.png
  • transform-origin (): 允许您更改转化元素位置

    image.png

3D转换

image.png
  • transform-origin(): 允许你改变被转换元素的位置。

    image.png
  • transform-style(): 规定被嵌套元素如何在 3D 空间中显示。

    image.png
  • perspective(): 规定 3D 元素的透视效果。

    image.png
  • perspective-origin(): 规定 3D 元素的底部位置。

    image.png
  • backface-visibility(): 定义元素在不面对屏幕时是否可见。

    image.png

过渡

元素从一种样式逐渐改变为另一种的效果

过渡属性

过渡属性.png
  • transition: property duration timing-function delay;
  • transition-property: none|all| property;属性指定CSS属性的nametransition效果
  • **transition-duration : time;属性规定完成过渡效果需要花费的时间(以秒或毫秒计)。
  • transition-timing-function: linear|ease|ease-in|ease-out|ease-in-out|cubic-bezier(n,n,n,n);属性指定切换效果的速度。
    transition-timing-function值.png
  • **ttransition-delay : time;属性指定何时将开始切换效果。
    transition-delay值是指以秒为单位(S)或毫秒(ms)。

多项改变

多项改变.png

与转换效果一起使用

与转换效果一起使用例子.png

动画

@keyframes 规则

要创建 CSS3 动画,你需要了解 @keyframes 规则。
@keyframes 规则是创建动画。
@keyframes 规则内指定一个 CSS 样式和动画将逐步从目前的样式更改为新的样式。
当在 @keyframes 创建动画,把它绑定到一个选择器,否则动画不会有任何效果。
指定至少这两个CSS3的动画属性绑定向一个选择器:

  • 规定动画的名称
  • 规定动画的时长


    规定动画的名称、时长.png

请用百分比来规定变化发生的时间,或用关键词 "from" 和 "to",等同于 0% 和 100%。


百分比.png
from" - "to.png

动画属性

  • @keyframes:规定动画。


    keyframes.png
  • animation:所有动画属性的简写属性,除了 animation-play-state 属性。


    animation.png
  • animation-name:规定 @keyframes 动画的名称。
  • animation-duration:定义动画完成一个周期需要多少秒或毫秒。默认是 0。
  • animation-timing-function:指定动画将如何完成一个周期。


    animation-timing-function.png
  • animation-fill-mode: 规定当动画不播放时(当动画完成时,或当动画有一个延迟未开始播放时),要应用到元素的样式。
    默认情况下,CSS 动画在第一个关键帧播放完之前不会影响元素,在最后一个关键帧完成后停止影响元素。animation-fill-mode 属性可重写该行为。


    animation-fill-mode.png
  • animation-delay:定义动画什么时候开始。单位可以是秒(s)或毫秒(ms)。默认是 0。


    animation-delay.png
  • animation-iteration-count:定义动画应该播放多少次。


    animation-iteration-count.png
  • animation-direction 属性定义是否循环交替反向播放动画。


    animation-direction.png
  • animation--play-state属性指定动画是否正在运行或已暂停。


    animation--play-state.png

动画常见坑

  1. @keyframes 不能实现突变的状态变化
    @keyframes 的原理是把样式的从一个状态,慢慢转变为另一个状态。例如:
* div 在2s内下移200px
*/
div {
    position:absolute;
    animation: move 2s;
}
@keyframes move {
    from { top:0; }
    to   { top:200px;}
}

上述div的移动,不是一步完成的,而是中间有很多个状态,从top:1px , 到top :2px , top: 3px ……最终到 top:200px; 这样一系列状态组成而构成的动画。
所以,如果不存在渐变的状态,是无法用@keyframes构成动画的,例如:

div {
    animation: apear 2s;
}
@keyframes appear {
    from { display:none; }
    to   { display:block;}
}

我们知道,display:none;是将div消失并且不占空间,display:block;则是将div展现存在并占据空间。但上述代码是无法使div拥有 2秒内从消失到展现 的渐变动画的,因为display:none;和display:block;是突变的,是从display:none;一下子到display:block;状态的。所以@keyframes无法实现。
同理其他种类的突变属性也无法拥有@keyframes的动画效果,@keyframes 只存在于渐变属性当中,例如各种width, height, opacity等属性值为数值的属性。

  1. @keyframes会增添/覆盖属性
/*
* div 在2s内下移200px
*/
div {
    position:absolute;
    top:0px;
    animation: move 2s;
}
@keyframes move {
    from { top:20px; }
    to   { top:200px;}
}

覆盖属性:如上述情况,div初始状态是top:0; @keyframes首先用top:20px覆盖原属性(top:0;),然后再启动@keyframes功能。 所以我们看到的效果是:div突然瞬间下降20px,然后在2秒内下降至指定位置(top:200px;)。

/*
* div 在2s内下移200px
*/
div {
    position:absolute;
    top:0px;
    animation: move 2s;
}
@keyframes move {
    from { top:0px; }
    to   { bottom:0px;}
}

添加属性:上述代码初始状态是div在顶部,最后状态是div 在底部,但像上面这样写 并不会出现div 从顶部慢慢下滑至底部的动画,而是div突然就出现在了底部。这是因为初始状态为div{ top:0px ;},但最终状态却不会是 div { bottom:0px; } , 而是 div { top:0px; bottom: 0px; } ,这样就会出现明显的错误,达不到我们预想的效果。

小结: @keyframes 中的属性,如果div本身存在该属性,就被@keyframes 中的属性给覆盖掉。 如果div本身不存在该属性,则为div增添该属性。

  1. 动画性能优化
    当你在使用@keyframes 动画时,如果做的动画比较复杂的话,就会发现一个问题,那就是不流畅,掉帧,可能在PC端还不是很明显,但在移动端你就会发现严重地掉帧。这是因为,如果@keyframes 改变的属性是与layout相关的话,就会触发重新布局,导致渲染和绘制的时间会更加地长。 所以,我们应该尽可能地使用不会触发重新布局的属性完成我们的动画。
    • 触发重新布局的属性有: width, height, margin, padding, border, display, top, right, bottom ,left, position, float, overflow等。应该尽量规避使用。
    • 不会出发重新布局的属性有:transform(其中的translate, rotate, scale), color, background等。应该尽量用这些去取代。
  2. 已知bug
    • iOS 6.1及以下不支持伪元素动画。iOS 7和更高的版本的伪元素动画会些问题。
    • Firefox 不支持@keyframes 在内联元素的使用。
    • 在Chorme中,如果使用了steps(x , start) ,animation-fill-mode backwards将会出错。如例子
    • 在IE10和IE11中,@keyframes不能在媒体查询@media内使用。

————————————————
参考链接:

相关文章

  • css3-转换/变形(transform)、过渡(transit

    转换(transform) 2D转换 translate(): translate.png rotate():...

  • css3-变形

    .css3-变形 transform 是css的变形属性,通过变形函数,设置具体的变形方式 scale()变形函数...

  • day08

    A 一、公共样式提取 二、css2d转换--transform属性 三、(css2d转换的)过渡--transit...

  • css3动画

    transform(变形),transition(过渡),animation(动画)一、transform:直接改...

  • CSS 之 tansition 过渡,transform 转换,

    transition 过渡 transform 转换 transform 3d转换 animation 动画

  • CSS变形、过渡和动画

    CSS实战手册 CSS变形,过渡和动画 1 变形 transform 1.1 旋转:rotate transfor...

  • css动画

    css3动画 过渡:transition 2D 转换 transform 3D 转换 transform 动画:a...

  • CSS3的transform

    CSS3 transform是什么?transform的含义是:改变,使…变形;转换CSS3 transform都...

  • transform

    CSS3 transform是什么?transform的含义是:改变,使…变形;转换CSS3 transform都...

  • 变形动画

    2. 如何使用变形动画? transform: 变形函数1 变形函数2 ...; 使用的前提是借助于过渡动画,才能...

网友评论

      本文标题:css3-转换/变形(transform)、过渡(transit

      本文链接:https://www.haomeiwen.com/subject/gnlejctx.html