码迷,mamicode.com
首页 > 移动开发 > 详细

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

时间:2020-03-17 13:50:36      阅读:90      评论:0      收藏:0      [点我收藏+]

标签:des   list   settime   func   win   问题   移动   click   tar   

移动端动画

技术图片

 

 红色勾勾代表强烈推荐

 

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>

技术图片

 

 

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

标签:des   list   settime   func   win   问题   移动   click   tar   

原文地址:https://www.cnblogs.com/chenyingying0/p/12510059.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!