zoukankan      html  css  js  c++  java
  • 移动端常见问题(动画演示)

    移动端动画

     红色勾勾代表强烈推荐

    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>

  • 相关阅读:
    欧几里得算法
    匈牙利算法找二分图最大匹配
    hdu3374 String Problem(最小值表示法 + KMP)
    hdu6704 K-th occurrence(后缀数组+RMQ+主席树)
    洛谷 P3809 【模板】后缀排序
    hdu2222 【AC自动机】Keywords Search
    2019杭电多校十 1011 Make Rounddog Happy(rmq + 分治)
    Separate String(Ac自动机+dp)
    2019杭电多校二 I Love Palindrome String(回文自动机)
    HDU2451 Simple Addition expression(数位dp/找规律)
  • 原文地址:https://www.cnblogs.com/chenyingying0/p/12510059.html
Copyright © 2011-2022 走看看