欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

移动端常见问题(动画演示)

程序员文章站 2022-03-25 17:50:32
移动端动画 红色勾勾代表强烈推荐 transition实现动画案例: 移动端动画

移动端动画

移动端常见问题(动画演示)

 

 红色勾勾代表强烈推荐

 

transition实现动画案例:

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>移动端动画</title>
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
    <style>
        *{padding:0;margin:0;}
        .box{width:100px;height: 100px;background-color: pink;transition:transform 1s;}
    </style>
</head>
<body>
    <button id="btn">start</button>
    <div class="box" id="box"></div>

    <script>
        var btn=document.getelementbyid("btn"),
            box=document.getelementbyid("box"),
            dest=window.innerwidth-100;//移动的距离

            btn.addeventlistener("click",function(){
                box.style.transform="translate3d("+dest+"px,0,0)";
            },false);    
    </script>
</body>
</html>

移动端常见问题(动画演示)

 

 也可以提取成函数的写法:

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>移动端动画</title>
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
    <style>
        *{padding:0;margin:0;}
        .box{width:100px;height: 100px;background-color: pink;transition:transform 1s;}
    </style>
</head>
<body>
    <button id="btn">start</button>
    <div class="box" id="box"></div>

    <script>
        var btn=document.getelementbyid("btn"),
            box=document.getelementbyid("box"),
            dest=window.innerwidth-100;//移动的距离

            btn.addeventlistener("click",function(){
                move(box,dest);
            },false);    

            function move(el,pos){
                el.style.transform="translate3d("+pos+"px,0,0)";
            }
    </script>
</body>
</html>

 

animation动画推荐一个animation库,animation.js  

可以查看各种动画的样式:

移动端常见问题(动画演示)

 

 

一般情况下推荐使用css3的transition和animation来完成动画,如果不能满足需求,可以考虑js的requestanimationframe

不做css动画时,记得一定要去掉transition属性

requestanimationframe的特点是:调用一次只执行一帧;如果想要持续执行,就需要递归。
<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>移动端动画</title>
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">
    <style>
        *{padding:0;margin:0;}
        .box{width:100px;height: 100px;background-color: pink;}
    </style>
</head>
<body>
    <button id="btn">start</button>
    <div class="box" id="box"></div>

    <script>
        //requestanimationframe的兼容性处理    
        var requestanimationframe=window.requestanimationframe||
        window.webkitrequestanimationframe||
        window.mozrequestanimationframe||
        window.msrequestanimationframe||
        window.orequestanimationframe||
        function(fn){
            settimeout(fn,16);
        }

        var btn=document.getelementbyid("btn"),
            box=document.getelementbyid("box"),
            dest=window.innerwidth-100,//移动的距离
            speed=1,
            pos=0;

        btn.addeventlistener("click",function(){
            requestanimationframe(step);
        },false);    

        function move(el,pos){
            el.style.transform="translate3d("+pos+"px,0,0)";
        }

        function step(){
            if(pos<dest){
                //递归
                pos+=speed;
                move(box,pos);
                requestanimationframe(step);
            }else{
                pos=dest;
                move(box,pos);
            }
        }
    </script>
</body>
</html>

移动端常见问题(动画演示)