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

2020-03-17 16:01:56来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

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

移动端动画

 

 红色勾勾代表强烈推荐

 

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  https://daneden.github.io/animate.css/

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

 

 

一般情况下推荐使用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>

 

 


原文链接:https://www.cnblogs.com/chenyingying0/p/12510059.html
如有疑问请与原作者联系

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:移动端常见问题(click 300ms延迟)

下一篇:练习中的零碎知识-CSS篇