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

首頁 > 編程 > HTML > 正文

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

2024-08-26 00:20:46
字體:
來源:轉載
供稿:網友

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

需求分析

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

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;}

可以看看大致的樣式:

Html5,移動端,無縫滾動,動畫

實現思路

一、使用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)        });

看看效果:

Html5,移動端,無縫滾動,動畫

二、使用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();

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

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


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美日韩国产一区中文午夜| 亚洲美女福利视频网站| 国产不卡精品视男人的天堂| 日韩激情视频在线播放| 国产91免费观看| 亚洲国产精品成人av| 欧美亚洲一区在线| 午夜精品蜜臀一区二区三区免费| 国产欧美日韩亚洲精品| 亚洲免费成人av电影| 久久久欧美精品| 国产亚洲欧洲黄色| 欧美高清视频在线| 久久精品久久久久电影| 亚洲女人天堂成人av在线| 日韩av黄色在线观看| 欧美一区二区三区精品电影| 日本精品久久电影| 伊人成人开心激情综合网| 中文字幕在线亚洲| 日韩av在线资源| 欧美电影在线观看完整版| 国产一区二区三区毛片| 亚洲第一福利网| 欧美成人免费一级人片100| 国产精品一区二区女厕厕| 在线日韩第一页| 午夜精品久久久久久久白皮肤| 色偷偷噜噜噜亚洲男人| 日本免费一区二区三区视频观看| 不卡av电影在线观看| 欧美激情精品久久久久| 久久久久北条麻妃免费看| 性夜试看影院91社区| 亚洲精品网址在线观看| 中文字幕自拍vr一区二区三区| 国产精品久久久久久一区二区| 亚洲日本成人网| 亚洲视频在线播放| 久久人人爽人人爽人人片av高请| 欧美超级免费视 在线| 亚洲国产福利在线| 国产精品免费久久久久久| 日本久久久久久久久久久| 亚洲一二三在线| 国产一区二区三区久久精品| 国产69久久精品成人看| 奇门遁甲1982国语版免费观看高清| 日韩成人免费视频| 精品久久久久久久久中文字幕| 韩国三级电影久久久久久| 欧美精品18videosex性欧美| 欧美高清无遮挡| 欧美激情视频一区二区| 国产精品9999| 亚洲精品97久久| 91av在线看| 成人黄色短视频在线观看| 4438全国成人免费| 国产成人拍精品视频午夜网站| 日韩精品中文字幕有码专区| 亚洲精品久久久久久久久久久久久| 国产精品久久激情| 亚洲欧美国产一区二区三区| 91产国在线观看动作片喷水| 日韩免费av在线| 69国产精品成人在线播放| 成人久久久久久久| 992tv在线成人免费观看| 成人激情视频在线观看| 亚洲欧美在线免费| 亚洲人成电影在线播放| 高跟丝袜一区二区三区| 久久久久久久久久久网站| 性视频1819p久久| 97超碰蝌蚪网人人做人人爽| 亚洲一区二区三区成人在线视频精品| 久久琪琪电影院| 久久久久久久网站| 午夜精品福利在线观看| 亚洲精品一区二区三区婷婷月| 一本大道香蕉久在线播放29| 国产精品电影观看| 欧美一级视频免费在线观看| 国产精品免费久久久久影院| 国产美女精品免费电影| 亚洲在线www| 亚洲石原莉奈一区二区在线观看| 国产成人精品久久久| 精品亚洲永久免费精品| 国产亚洲精品一区二555| 亚洲高清一二三区| 日韩中文字幕在线播放| 亚洲v日韩v综合v精品v| 91久久国产综合久久91精品网站| 久久久av免费| 久久久久国产精品免费网站| 秋霞成人午夜鲁丝一区二区三区| 国产成人a亚洲精品| 国内成人精品一区| 亚洲**2019国产| 91精品国产综合久久香蕉| 色99之美女主播在线视频| 国产91成人video| 日韩av片永久免费网站| 国产精品人成电影| 久久精品在线播放| 欧美高清一级大片| 日本中文字幕久久看| 久久久久久久久久久免费| 激情懂色av一区av二区av| 亚洲精品美女久久久| 91精品久久久久久久久青青| 久久久久久噜噜噜久久久精品| 亚洲综合色激情五月| 欧美日韩国产精品一区二区三区四区| 亚洲二区中文字幕| 亚洲跨种族黑人xxx| 26uuu久久噜噜噜噜| 欧美另类精品xxxx孕妇| 日韩最新中文字幕电影免费看| 国产男女猛烈无遮挡91| 91爱视频在线| 国产91在线播放精品91| 97香蕉超级碰碰久久免费的优势| 欧美激情免费在线| 欧美孕妇孕交黑巨大网站| 亚洲精品久久视频| 国产精品99久久久久久www| 国产精品扒开腿做爽爽爽的视频| 大伊人狠狠躁夜夜躁av一区| 91久久在线观看| 日韩69视频在线观看| www国产精品com| 国产精品日韩av| 欧美日韩福利在线观看| 国产精品欧美日韩久久| 欧美成人精品影院| 国产精品女主播| 欧美壮男野外gaytube| 国产亚洲精品久久| 亚洲欧美国产一区二区三区| 日韩欧美成人免费视频| 91在线免费网站| 91亚洲va在线va天堂va国| 亚洲一区二区三区香蕉| 中文字幕亚洲二区| 91久久久久久| 国产精品久久久久9999| 一个色综合导航| 日韩在线中文视频| 亚洲xxxxx性| 亚洲国产成人精品久久久国产成人一区| 欧美日韩色婷婷| 欧美视频国产精品| 亚洲国产女人aaa毛片在线| 欧美成人亚洲成人日韩成人| 日韩av色综合| 啪一啪鲁一鲁2019在线视频| 国产一区二区三区高清在线观看| 国产主播精品在线| 91在线观看免费高清完整版在线观看| 欧美在线视频导航| 亚洲国产精品系列|