>  기사  >  웹 프론트엔드  >  전환을 사용하여 전환 애니메이션 구현

전환을 사용하여 전환 애니메이션 구현

高洛峰
高洛峰원래의
2017-03-15 10:24:512213검색

애니메이션은 다음과 같이 구분됩니다.

1.css3 애니메이션: ( animation js)

 보다 성능이 훨씬 높습니다. 1) . 전환 애니메이션(전환)

 🎜> 2).키프레임 애니메이션(@keyframes, 애니메이션 )

2.js 애니메이션:

전환 애니메이션(전환)

구문: (모든 기간 단위는 초 )

1. 변경속성(transition-property(속성명))

2. Duration(전환-기간(duration))*이 속성에는 다음이 있어야 합니다(기본 시간은 "0")

3. 전환 타이밍 기능

4 . 지연 시간(전환-지연)

원래 상태로 돌아갑니다

전환을 사용하여 전환 애니메이션 구현

전환 -timing-function: 변화율

1.ease(기본값): 먼저 빠르다가 빠르다가 느림

2.ease-in: 페이드 인(애니메이션이 처음부터 천천히 변경됨)

3.ease-out: 페이드 아웃(애니메이션이 끝날 때 천천히 변경됨) ) 🎜>

6.cubic-bezier: 베지어 곡선, 모든 변환은 베지어로 가능                    큐빅 베지어(x1,y1,x2,y2), x1, y1, x2, y2의 값은 0~1 범위에 있습니다.                                    

过渡动画没有自己的触发时机,只有以下几种,可以触发过渡动画:

1.:hover(最常用)

2.:focus

3.:checked(多选输入框被勾选的状态)

4.媒体查询(@media screen and(条件){样式})

5.js

전환을 사용하여 전환 애니메이션 구현

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>过渡动画</title>
        <style type="text/css">
            .p1{
                width: 200px;
                height: 200px;
                background: green;
                /*变化属性:
                     默认值为all指代所有的属性(不写,默认该元素身上所有属性的值的更改,
                       都支持动画效果)
                 */
                transition-property:all;
                /*多组值之间用","隔开*/
                transition-property: width,background;
                /*持续时长,默认值为"0",就是没有动画(设置过渡动画一定不能省略)*/
                transition-duration: 2s;
                /*变化速率
                     四个值:1.ease(默认值):先快再快再慢
                            2.ease-in:淡入(动画刚开始的时候变化慢)
                            3,ease-out:淡出(动画快结束的时候变化慢)
                            4.ease-in-out:淡入淡出
                            5.linear:匀速变化
                            6.cubic-bezier:贝塞尔曲线,所有的变化都可以用贝塞
                              尔曲线来代替
                              cubic-bezier(x1,y1,x2,y2),x1,y1,x2,y2值的范围
                                 都是0~1
                 */
                transition-timing-function: cubic-bezier(0.4,0.2,0.5,0.7);
                /*延迟时长:延迟多久开始*/
                transition-delay: 2s;
                /*transition: all width,background 2s cubic-bezier(0.4,0.2,0.5,0.7) 2s;*/
            }
            /*再触发时机中,更改你想要看属性动画的那个属性的值*/
            .p1:hover{
                width: 500px;
                background: pink;
                height: 500px;
            }
            .p2{
                width: 200px;
                height: 200px;
                background: pink;
                /*过渡动画*/
                transition: all 2s linear ;  
            }
            .p2:hover{
                /*所有的属性都支持形变的*/
                /*transform:多组形变用空格
                 background:多组之间用","号
                */
                /*形变中平移其实真正的位置没有改变,移动就是个假象*/
                /*transform: translate(300px,100px) ;*/
                opacity: 0.5;
                /*margin-left:是真实改变*/
                margin-left: 300px;
            }
            .text{
                transition: 2s;
                height: 100px;
            }
            /*过渡动画的focus时机*/
            .text:focus{
                height: 300px;
            }
            .check{
                margin-top: 50px;
                transition: 2s;
            }
            .check:checked{
                margin-top: 200px;
            }
            
            
            .p3{
                width: 200px;
                height: 200px;
                background: yellow;
                transition: 2s;
            }
            @media only screen and (min-width:800px ) {
                .p3{
                    width: 500px;
                }
            }
        </style>
    </head>
    <body>
        <p>eg1:</p>
        <p class="p1"></p>
        <hr />
        
        <p>eg2:</p>
        <p class="p2"></p>
        <hr />
        
        <p>eg3:</p>
        <form action="###">
            <!--
                input:我们没有设置宽高,就可以看到它(特殊性),对于它设置宽高
                动画的时候,避免兼容性问题,一般要设置初始宽高
                *所有属性设置过渡动画的时候,一般给该属性设置初始值
            -->
            <input type="text" class="text" value="" />
            <br />
            <input type="checkbox" class="check" />
        </form>    
        <hr /
        
        <p>eg4:</p>
        <!--媒体查询时机的例子-->
        <p class="p3"></p>
    </body>
</html>


위 내용은 전환을 사용하여 전환 애니메이션 구현의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.