成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

avalon js+css3實現(xiàn)roundabout 圖片輪播

AlphaGooo / 584人閱讀

摘要:效果效果就像優(yōu)酷綜藝頻道頁面的圖片輪播。本屌之前做過這個參見仿優(yōu)酷頻道首頁的圖片切換效果不過用的是類似的庫做的。

roundabout效果

效果就像優(yōu)酷綜藝頻道頁面的圖片輪播。
本屌之前做過這個roundabout,參見仿優(yōu)酷頻道首頁的圖片切換效果,不過用的是類似jquery的庫做的。盡管js代碼不到200行,但還是顯得有點復(fù)雜。于是乎,本屌盤算著可不可以用更少的代碼完成這個效果。
順便說一下,如果有讀者想造輪子,可以直接看優(yōu)酷的js代碼,基本上都沒壓縮,封裝這個效果的代碼在posterTvGrid.js
下面是本屌做出來的效果
http://v.youku.com/v_show/id_XMTM1ODk4NDQyNA==.html

要求

點擊左右箭頭,圖片滾動

點擊下面圖片索引,如果點擊的圖片是當(dāng)前圖片或與當(dāng)前圖片相鄰的圖片,則圖片滾動;否則,所有圖片先變小,然后點擊的圖片和與之相鄰的圖片,在相應(yīng)位置動態(tài)變大。

代碼盡可能少,盡可能清晰

布局
    

圖片的位置有2種情況:

不可見,即不是前面的3張圖片,這里類名.hide

.hide {
  width: 530px;
  height: 100px;
  opacity: 0;
  z-index: 0;
  margin-top: 0;
  left: -530px;
}

可見的3張圖片,按位置具體可分為.left,.middle,.right

.middle {
  width: 640px;
  height: 270px;
  opacity: 1;
  z-index: 2;
  margin-top: 0;
  left: 275px;
}
.left {
  width: 530px;
  height: 224px;
  opacity: 0.4;
  z-index: 1;
  margin-top: 23px;
  left: 0;
}
.right {
  width: 530px;
  height: 224px;
  opacity: 0.4;
  z-index: 1;
  margin-top: 23px;
  left: 660px;
}

每個類的6個屬性都是和圖片尺寸(640*270)配合好的,使得動畫很自然。當(dāng)然后面會用到css3 animation,使每張圖片的這6個屬性進行相應(yīng)的變化。
下面把上面類添加到相應(yīng)圖片上

    var roundabout=avalon.define({
        $id:"roundabout",
        img_list:[],
        cur:0,//當(dāng)前頁
        ...
    });

cur相對于指針,表示當(dāng)前中間(可見范圍最大)圖片是圖片列表里的哪張圖片,所以會有(從左向右看)

cur=>.middle

cur+1=>.right

cur-1=>.left

其他=>.hide

插值表達式中的邏輯運算符

這里就要把邏輯運算符用到插值表達式里

解釋下
ms-class-middle="$index==cur"
這個很簡單,指針的當(dāng)前位置,添加.middle.

ms-class-left="$index==cur-1||(cur==0&&$index==img_list.size()-1)"
后面部分表示,如果指針在第一張圖片那里,就在最后一張圖片上添加.left.

ms-class-right="$index==cur+1||(cur==img_list.size()-1&&$index==0)"
和上面類似,后面部分表示,如果指針在最后一張圖片那里,就在第一張圖片上添加.right.

ms-class-hide="($indexcur+1&&(cur!=0||$index!=img_list.size()-1))"
由兩個大或(||)組成

前面部分$index表示在cur-1(左邊的可見)圖片以左的圖片,都會添加.hide隱藏,除開一種情況,當(dāng)前指針在最后一張圖片那里時,圖片列表中的第一張圖片不能添加.hide,因為它將被添加.right.

這里利用了||運算符的特點,如果第一個條件滿足的話,就不會去判定第二個條件;第一個條件不滿足時,才會去判定第二個條件。

后面部分$index>cur+1&&(cur!=0||$index!=img_list.size()-1)表示在cur+1(右邊的可見)圖片以右的圖片,都會添加.hide隱藏,除了當(dāng)前指針在第一張圖片那里時,圖片列表中的最后一張圖片不能添加.hide,因為它將被添加.left.

實際上,用離散數(shù)學(xué)里的非(p且q)=非p或非q就很好想了,除開已經(jīng)添加了.left,.middle,.right的圖片,剩下的就得添加.hide,$index>cur+1$index可以保證$index!=cur.

然后是排除.left,滿足.left的條件是$index==cur-1||(cur==0&&$index==img_list.size()-1),它的否定是$index!=cur-1&&(cur!=0||$index!=img_list.size()-1),這就和添加.hide的條件的左邊部分一樣了。

排除.right也是類似的。

把這兩個部分組合起來就可以保證.left,.middle,.right,.hide這4個類之間是互斥的。

當(dāng)然也可以利用css優(yōu)先級,讓.left,.middle,.right類的優(yōu)先級高于.hide,這樣添加.hide的判定條件會簡單很多。為了嚴(yán)謹(jǐn)些,就沒有用這種方式。

圓點序列
        

cur==$index讓"亮"的圓點和當(dāng)前指針同步。
到這里,任意改變roundabout.cur=?都可以呈現(xiàn)roundabout布局。

圖片滾動 定義css3 animation

滾動過程中,要滾動圖片有4種動畫狀態(tài),以向右滾動為例

左邊可見的圖片的上(左)一張圖片,不可見=>在可見部分左邊,部分可見

原來左邊可見的圖片,在可見部分左邊,部分可見=>中間,全部可見

原來中間全部可見的圖片,中間,全部可見=>在可見部分右邊,部分可見

原來右邊可見的圖片,在可見部分右邊,部分可見=>不可見
這里用css3 animation

@keyframes to-right1 {//向右滾動
  0% {
    width: 530px;
    height: 100px;
    opacity: 0;
    z-index: 0;
    margin-top: 85px;
    left: -530px;
  }
  100% {
    width: 530px;
    height: 224px;
    opacity: 0.4;
    z-index: 1;
    margin-top: 23px;
    left: 0;
  }
}
@keyframes to-right2 {
  0% {
    width: 530px;
    height: 224px;
    opacity: 0.4;
    z-index: 1;
    margin-top: 23px;
    left: 0;
  }
  100% {
    width: 640px;
    height: 270px;
    opacity: 1;
    z-index: 2;
    margin-top: 0;
    left: 275px;
  }
}
@keyframes to-right3 {
  0% {
    width: 640px;
    height: 270px;
    opacity: 1;
    z-index: 2;
    margin-top: 0;
    left: 275px;
  }
  100% {
    width: 530px;
    height: 224px;
    opacity: 0.4;
    z-index: 1;
    margin-top: 23px;
    left: 660px;
  }
}
@keyframes to-right4 {
  0% {
    width: 530px;
    height: 224px;
    opacity: 0.4;
    z-index: 1;
    margin-top: 23px;
    left: 660px;
  }
  100% {
    width: 530px;
    height: 100px;
    opacity: 0;
    z-index: 0;
    margin-top: 85px;
    left: 1190px;
  }
}
...

可以看到,動畫無非是在.hide,.left,.middle,.right這4個狀態(tài)間切換。

@keyframes to-right1 {//向右滾動
    0% {
      //.hide
    }
    100% {
      //.left
    }
}
@keyframes to-right2{
    0% {
        //.left
    }
    100% {  
        //.middle
    }
}
@keyframes to-right3{
    0% {
        //middle
    }
    100% {  
        //right
    }
}
@keyframes to-right4{
    0% {
        //right
    }
    100% {  
        //hide1
    }
}
...

為了方便編碼,用less

.state(@width,@height,@opacity,@z-index,@margin-top,@left){
    width: @width;
    height: @height;
    opacity: @opacity;
    z-index: @z-index;
    margin-top: @margin-top;
    left:@left;
}
.middle(){
    .state(640px,270px,1,2,0,275px);
}
.left(){
    .state(530px,224px,0.4,1,23px,0);
}
.right(){
    .state(530px,224px,0.4,1,23px,660px);
}
.hide(){
    .state(530px,100px,0,0,85px,-530px);
}
.hide1(){
    .state(530px,100px,0,0,85px,1190px);
}
.middle{
    .middle();
}
.left{
    .left();
}
.right{
    .right();
}
.hide{
    .hide();
}
@keyframes to-right1{//向右滾動
    0% {
        .hide();
    }
    100% {  
        .left();
    }
}
@keyframes to-right2{
    0% {
        .left();
    }
    100% {  
        .middle();
    }
}
@keyframes to-right3{
    0% {
        .middle();
    }
    100% {  
        .right();
    }
}
@keyframes to-right4{
    0% {
        .right();
    }
    100% {  
        .hide1();
    }
}
...
點擊左右箭頭,圖片滾動
    var roundabout=avalon.define({
        $id:"roundabout",
        img_list:[],
        cur:0,//當(dāng)前頁
        jump:function(i,dir){//dir:滾動方向
            roundabout.cur=i;
        }
    });
    
...

jump方法的dir參數(shù)后面會用到。
這里還沒有添加動畫類,只能進行沒有動畫的滾動。

添加動畫
//所有的動畫類
var animate_class="to-right1 to-right2 to-right3 to-right4 to-left1 to-left2 to-left3 to-left4";
...
jump:function(i,dir){
    if(dir==1){//向右滾 cur-1
        avalon($("img"+prev(i))).removeClass(animate_class).addClass("to-right1");
        avalon($("img"+i)).removeClass(animate_class).addClass("to-right2");
        avalon($("img"+next(i))).removeClass(animate_class).addClass("to-right3");
        avalon($("img"+next(next(i)))).removeClass(animate_class).addClass("to-right4");
    }else{//向左滾 cur+1
        avalon($("img"+next(i))).removeClass(animate_class).addClass("to-left1");
        avalon($("img"+i)).removeClass(animate_class).addClass("to-left2");
        avalon($("img"+prev(i))).removeClass(animate_class).addClass("to-left3");
        avalon($("img"+prev(prev(i)))).removeClass(animate_class).addClass("to-left4");
    }
    roundabout.cur=i;
}
...
function prev(now){//上一頁
    return now==0?roundabout.img_list.size()-1:now-1;
}
function next(now){//下一頁
    return now==roundabout.img_list.size()-1?0:now+1;
}

幾點說明

這里的removeClass方法和jquery中的一樣,當(dāng)傳入?yún)?shù)像上面animate_class變量,多個類以空格分開時,對目標(biāo)刪除多個類(如果有的話)。

prev,next方法用來得到上一張圖片和下一張圖片的在圖片列表中的索引.注意next(next(i))不等于next(i+1).

添加動畫類之前,要先刪除所有可能存在的動畫類。

點擊圓點,圖片滾動

和點擊左右箭頭,圖片滾動的動畫不一樣,這里對目標(biāo)圖片及其左右圖片是一個從小變大的動畫效果。

.state(@width,@height,@opacity,@z-index,@margin-top,@left){
    width: @width;
    height: @height;
    opacity: @opacity;
    z-index: @z-index;
    margin-top: @margin-top;
    left:@left;
}
.jump-state(){
    .state(0,0,0,0,135px,585px);
}
@keyframes jump-prev{//變小->左邊圖片
    0% {
        .jump-state();
    }
    100% {  
        .left();
    }
}
@keyframes jump-middle{//變小->中間圖片
    0% {
        .jump-state();
    }
    100% {  
        .middle();
    }
}
@keyframes jump-next{//變小->右邊圖片
    0% {
        .jump-state();
    }
    100% {  
        .right();
    }
}

下面對圓點綁定點擊事件

spec_jump:function(i){
    var cur=roundabout.cur;
    if(cur-prev(i)==0||cur-next(i)==0){//如果點擊的圖片是當(dāng)前圖片或當(dāng)前圖片的相鄰圖片
        var dir=1;//確定滾動方向
        if(cur-prev(i)==0)
            dir=2;
        roundabout.jump(i,dir);
    }else{
        roundabout.cur=i;
        avalon($("img"+prev(i))).removeClass(animate_class).addClass("jump-prev");
        avalon($("img"+i)).removeClass(animate_class).addClass("jump-middle");
        avalon($("img"+next(i))).removeClass(animate_class).addClass("jump-next");
    }
}

這里會添加jump-prev,jump-middle,jump-next類,所以前面的animate_class變量也要加上這3個類。

后記

js代碼不超過50行,當(dāng)然css代碼多點,不過用less寫的話,編程體驗很好

下載

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/111169.html

相關(guān)文章

  • avalon js+css3實現(xiàn)roundabout 圖片輪播

    摘要:效果效果就像優(yōu)酷綜藝頻道頁面的圖片輪播。本屌之前做過這個參見仿優(yōu)酷頻道首頁的圖片切換效果不過用的是類似的庫做的。 roundabout效果 效果就像優(yōu)酷綜藝頻道頁面的圖片輪播。本屌之前做過這個roundabout,參見仿優(yōu)酷頻道首頁的圖片切換效果,不過用的是類似jquery的庫做的。盡管js代碼不到200行,但還是顯得有點復(fù)雜。于是乎,本屌盤算著可不可以用更少的代碼完成這個效果。順便說...

    Awbeci 評論0 收藏0
  • 基于CSS3實現(xiàn)淡入(fadeIn)淡出(fadeOut)效果

    摘要:網(wǎng)上的淡入淡出效果大多是依照中和的方法使用來控制元素的透明度達到目的,但缺點是有輕微的卡頓感,并且運行效率一般。思路是將淡入,淡出的效果做成預(yù)先定義好的樣式類,然后用改變元素的類來達到圖片輪播。 網(wǎng)上的淡入淡出效果大多是依照jquery中fadeIn和fadeOut的方法使用js來控制元素的透明度達到目的,但缺點是有輕微的卡頓感,并且運行效率一般。 這里提供另外一個思路,即通過預(yù)先定義...

    XUI 評論0 收藏0
  • CSS3 transition屬性實現(xiàn)淡入淡出輪播

    摘要:最近想自己寫下輪播圖,在網(wǎng)上發(fā)現(xiàn)一個網(wǎng)友用屬性實現(xiàn)的輪播,趕腳超簡單哦,自己學(xué)習(xí)了后整理如下。如果我們用給加上類,的就要變成對吧,由于有屬性,所以要等,才能完全變?yōu)?,實現(xiàn)了淡入。最近想自己寫下輪播圖,在網(wǎng)上發(fā)現(xiàn)一個網(wǎng)友用CSS transition屬性實現(xiàn)的輪播,趕腳超簡單哦,自己學(xué)習(xí)了后整理如下。(找不到原網(wǎng)址了-.-...就不貼了...)(如果不了解transition,先去這里(點我,...

    Heier 評論0 收藏0
  • 小小幻燈片

    摘要:上一篇說了瀑布流,今天說一下小小幻燈片的故事?;脽羝瑢W(xué)名又叫輪播。輪播原理這里先說一下基本原理吧,就是將圖片向左或向右移,然后接著顯示下一張,或者上一張。這里需要感謝一下愛編程提供的圖片接著重頭戲就是。用來標(biāo)識當(dāng)前的元素的序號。 上一篇說了瀑布流,今天說一下小小幻燈片的故事。 幻燈片學(xué)名又叫 輪播。應(yīng)該算是一種最常用的頁面展示信息。以前由于ie6/7的拖累,導(dǎo)致我們只能使用,很古老的方...

    anonymoussf 評論0 收藏0
  • 面試官(6): 寫過『通用前端組件』嗎?

    摘要:很久沒上掘金發(fā)現(xiàn)草稿箱里存了好幾篇沒發(fā)的文章最近梳理下發(fā)出來往期面試官系列如何實現(xiàn)深克隆面試官系列的實現(xiàn)面試官系列前端路由的實現(xiàn)面試官系列基于數(shù)據(jù)劫持的雙向綁定優(yōu)勢所在面試官系列你為什么使用前端框架前言設(shè)計前端組件是最能考驗開發(fā)者基本功的測 很久沒上掘金,發(fā)現(xiàn)草稿箱里存了好幾篇沒發(fā)的文章,最近梳理下發(fā)出來 往期 面試官系列(1): 如何實現(xiàn)深克隆 面試官系列(2): Event Bus...

    waltr 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<