亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > HTML5 > 正文

Html5移動端獲獎無縫滾動動畫實現示例

2024-09-05 07:19:22
字體:
來源:轉載
供稿:網友

本文介紹了Html5移動端獲獎無縫滾動動畫實現示例,分享給大家,具體如下:

需求分析

哈哈,上動態圖真的是一下就明了了。

就是滾動么滾動,那么制作這個有什么方法呢?我們來總結一下:

html骨架

其實很簡單,最外面的<div>是做固定的窗口,里面的<ul>控制運動,<li>里面是展示動畫

<div class="roll" id="roll">    <ul>         <li>第一個結構</li>         <li>第二個結構</li>         <li>第三個結構</li>         <li>第四個結構</li>         <li>第五個結構</li>         <li>第六個結構</li>         <li>第七個結構</li>         <li>第八個結構</li>    </ul></div>

基本css樣式

先把基本的css樣式實現

*{    margin:0;    padding:0;}.roll{    margin: 100px auto;    width: 200px;    height: 40px;    overflow:hidden;    border: 1px solid aquamarine;}.roll ul{    list-style: none;}.roll li{    line-height:20px;    font-size:14px;    text-align:center;}

可以看看大致的樣式:

實現思路

一、使用jquery的animate動畫

animate()方法

$(selector).animate(styles,speed,easing,callback)

參數:
styles:必需參數,需要產生動畫的css樣式(使用駝峰式命名)
speed: 規定動畫的速度
@number:1000(ms)
@string:"slow","normal","fast"
easing:動畫速度(swing,linear)
callback:函數執行完之后的回調函數

    $(document).ready(function(){            setInterval(function(){  // 添加定時器,每1.5s進行轉換                $("#roll").find("ul:first").animate({                        marginTop:"-40px"  //每次移動的距離                },500,function(){   // 動畫運動的時間                        //$(this)指的是ul對象,                        //ul復位之后把第一個元素和第二個元素插入                        //到ul的最后一個元素的位置                        $(this).css({marginTop:"0px"}).find("li:first").appendTo(this);                        $(this).find("li:first").appendTo(this);                });            },1500)        });

看看效果:

二、使用css3的animation動畫

通過css3中的關鍵幀,可以得到跳步的效果。先通過一個短的看一下思路。

初步

1.如果是寫死的獲獎,那么需要把前面的那個復制一份到后面去,如果是一個一個滾動那么就復制第一個,如果是兩個兩個滾動的就復制第一個和第二個。

<div class="roll" id="roll">        <ul>             <li>第一個結構</li>             <li>第二個結構</li>             <li>第三個結構</li>             <li>第四個結構</li>             <li>第五個結構</li>             <li>第六個結構</li>             <li>第七個結構</li>             <li>第八個結構</li>             <li>第一個結構</li>             <li>第二個結構</li>        </ul></div>

2.然后計算需要滾動多少次,一次多少秒,例子是兩個兩個滾動,需要5s,所以css3的animation的時間是5s。那么@keyframe需要分成幾份呢?因為是停頓,每一個滾動都需要兩份,最后一個要跳動所以只有一份,所以需要5 * 2 - 1 = 9份,看代碼就曉得了:

/*這里不做兼容性處理*/.roll ul{    list-style: none;    animation: ani 5s  linear infinite;  /*動畫ani,5s,循環勻速播放*/}@keyframes ani{      0%{        margin-top: 0;    }    12.5%{        margin-top: 0;    }    25%{        margin-top: -40px;    }    37.5%{        margin-top: -40px;    }    50%{        margin-top: -80px;    }    62.5%{        margin-top: -80px;    }    75%{        margin-top: -120px;    }    87.5%{        margin-top: -120px;    }    100%{        margin-top: -160px; /*最后是一個,這樣可以打斷動畫*/    }}

進階

如果個數不確定,那么就需要動態的計算,用js動態地添加@keyframes ,到時候只要自己可以計算清楚間隔還有移動的距離就好。

1.首先獲取<li>的長度length
2.然后計算間隔百分比,因為有停頓所以記得要用秒數×2
3.然后用字符串拼寫@keyframes,0~length,包括length,因為多一個,雙數和單數分開。
4.把<ul>中的第一個和第二個克隆到<ul>的最后
5.創建一個<style>標簽加入到<head>中
6.給<ul>添加動畫屬性

話不多說上代碼:

   function addKeyFrame(){       var ulObj = $("#roll ul"),  //獲取ul對象             length = $("#roll li").length,  //獲取li數組長度             per = 100 / (length / 2 * 2 );  //計算中間間隔百分比       // 拼接字符串       var keyframes = `/           @keyframes ani{`;       for(var i = 0 ; i<=length ; i++ ){           keyframes+=`${i * per}%{                           margin-top: ${i % 2 == 0 ? -i * 20 : -(i - 1) * 20}px;                       }`;       }       keyframes+='}';       var liFirst = $("#roll li:first"),   //獲取第一個元素           liSec = liFirst.next();    //獲取第二個元素       ulObj.append(liFirst.clone()).append(liSec.clone());   //將兩個元素插入到ul里面       $("<style>").attr("type","text/css").html(keyframes).appendTo($("head"));    //創建style標簽把關鍵幀插入到頭部       ulObj.css("animation","ani 5s linear infinite");  //給ul添加css3動畫   }   addKeyFrame();

三、zepto+transition實現

移動端的zepto沒有animate函數,如果不用css3的屬性,那如何用js去寫?

var timer,top;function roll(){    var ulObj = $("#roll").find("ul"),        length = $("#roll li").length,          liFirst = $("#roll").find("li:first");        liSec = liFirst.next();    ulObj.append(liFirst.clone()).append(liSec.clone());  //把第一個第二個都添加到<ul>標簽中    clearInterval(timer);    timer = setInterval(function(){  //設置定時器        var top = ulObj.css("margin-top");        top = +top.slice(0,-2);        if(top != -(20 * length)){  //獲取現在的高度如果沒有到最后就上移            top -= 40;            ulObj.css({"-webkit-transition":"all 1s","transition":"all 1s","margin-top":top});        }else{  //如果到了最后就迅速到零            top = 0;            ulObj.css({"-webkit-transition":"none","transition":"none","margin-top":top});            setTimeout(function(){  //這里加一個延時器,也是要放在隊列最后去執行,為了避免兩個動畫合并                top -= 40;                ulObj.css({"-webkit-transition":"all 1s","transition":"all 1s","margin-top":top});            },0)        }    },2000);}roll();

如果還有別的方法,下次我會不定期更新的。不過移動端的話這幾個應該夠用了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91国内揄拍国内精品对白| 日韩高清av在线| 欧美国产日韩一区二区三区| 日韩av网站电影| 最近中文字幕mv在线一区二区三区四区| 日韩在线观看免费网站| 欧洲中文字幕国产精品| 日韩动漫免费观看电视剧高清| 91午夜理伦私人影院| 91免费高清视频| 久久不射电影网| 欧美精品在线极品| 一区二区三区www| 久久久国产一区二区| 久久久噜噜噜久久中文字免| 日韩在线观看精品| 欧美成人激情视频| 成人精品久久一区二区三区| 亚洲国产精品小视频| 久久精品国产久精国产思思| 日韩中文字幕在线免费观看| 国产亚洲精品美女久久久久| 高跟丝袜一区二区三区| 精品美女永久免费视频| 97在线视频国产| 欧美老少做受xxxx高潮| 成年人精品视频| 国产在线观看一区二区三区| 久久久国产精彩视频美女艺术照福利| 久久久久久91香蕉国产| 国产三级精品网站| 久久久精品电影| 北条麻妃一区二区三区中文字幕| 亚洲激情在线观看视频免费| 国产精品久久不能| 久久久国产一区| 国产精品久久久久久久久久ktv| 欧美成人精品h版在线观看| 国产三级精品网站| 91免费精品国偷自产在线| 综合网中文字幕| 久久久国产一区二区三区| 久久久噜噜噜久噜久久| 青青a在线精品免费观看| 91tv亚洲精品香蕉国产一区7ujn| 久久视频在线观看免费| xxx欧美精品| 亚洲影院色在线观看免费| 亚洲性av在线| 亚洲xxx自由成熟| 97免费视频在线| 91免费欧美精品| 久久精品国产亚洲一区二区| 日韩欧美中文第一页| 国产精品久久久久久久美男| 日韩av中文在线| 亚洲电影在线观看| 日韩av影视综合网| 亚洲另类图片色| 国产成人欧美在线观看| 色综合色综合网色综合| 欧美在线不卡区| 亚洲高清色综合| 日本高清不卡在线| 亚洲精品一区二区三区婷婷月| 日韩福利伦理影院免费| 久久久久久久久久av| 欧美成年人视频网站| 亚洲电影免费观看高清完整版在线观看| 日韩av免费在线播放| 欧美日韩国产中文精品字幕自在自线| 欧美午夜激情小视频| 亚洲第一中文字幕| 久久久久久网址| 国产精品免费一区二区三区都可以| 国产精品自拍视频| 97视频在线观看免费高清完整版在线观看| 亚洲aⅴ日韩av电影在线观看| 国产成人极品视频| 国产亚洲精品激情久久| 欧美精品aaa| 国产综合在线观看视频| 日韩av综合中文字幕| 久久精品国产亚洲| 日韩激情av在线免费观看| 欧美日韩国产va另类| 久久久天堂国产精品女人| 中文字幕精品网| 日韩欧美国产免费播放| 国产91精品久久久久| 亚洲免费小视频| 亚洲国产欧美一区二区三区久久| 国产免费一区二区三区香蕉精| 精品国产91久久久久久老师| 热re99久久精品国产66热| 国产精品一区二区三区成人| 亚洲欧美一区二区三区情侣bbw| 精品福利在线观看| 日韩av在线直播| 亚洲国产中文字幕在线观看| 另类少妇人与禽zozz0性伦| 亚洲一区二区日本| 亚洲国产精品免费| 亚洲永久在线观看| 日韩一区二区在线视频| 亚洲精品国产精品自产a区红杏吧| 国产精品爽黄69天堂a| 亚洲精品久久久久中文字幕欢迎你| 成人黄色免费看| 狠狠躁夜夜躁人人爽超碰91| 久久久亚洲成人| 亚洲第一视频网| 在线观看免费高清视频97| 宅男66日本亚洲欧美视频| 亚洲日本中文字幕免费在线不卡| 国内精品国产三级国产在线专| 国产精品露脸av在线| 亚洲国产精品久久精品怡红院| 欧美在线不卡区| 日本一欧美一欧美一亚洲视频| 国产精品视频一区二区三区四| 久久精品99久久久久久久久| 欧美激情在线播放| 国产午夜精品一区二区三区| 久久香蕉国产线看观看网| 欧美高清视频一区二区| 久久久久久国产精品久久| 亚洲xxxx做受欧美| 这里只有精品在线播放| 97在线视频一区| 国内精品久久久久久| x99av成人免费| 国产欧美精品一区二区三区介绍| 亚洲香蕉成人av网站在线观看| 国产女精品视频网站免费| 久久久噜噜噜久噜久久| 精品日本高清在线播放| 欧美超级免费视 在线| 国产日本欧美一区二区三区在线| 日韩精品免费视频| 亚洲国产私拍精品国模在线观看| 欧美在线激情视频| 狠狠做深爱婷婷久久综合一区| 国产精品av在线| 亚洲第一区第一页| 亚洲区免费影片| 国产精品视频午夜| 亚洲黄色免费三级| 91丨九色丨国产在线| 亚洲欧美中文日韩在线| 国产精品美女呻吟| 亚洲欧美日韩视频一区| 亚洲欧洲一区二区三区在线观看| 欧美高清视频一区二区| 国产精品成人av性教育| 日韩精品免费在线| 91久久久久久久久久久| 97国产一区二区精品久久呦| 在线观看国产成人av片| 国产美女扒开尿口久久久| 国产精品久久久久久av下载红粉| 日韩欧亚中文在线| 国产成人精品电影久久久| 国产精品私拍pans大尺度在线|