js CSS3實(shí)現(xiàn)卡牌旋轉(zhuǎn)切換效果
我們經(jīng)常會在游戲里看到一些幾張卡牌左右切換的效果,中間的一張最突出醒目,向左或向右滑動可切換到另一張,今天我們就用CSS3來實(shí)現(xiàn)下這種效果。
我們先來看個demo,具體的樣式各位可以自己調(diào)整:
(PC下可點(diǎn)擊按鈕切換,移動端可左右滑動切換)
從效果上我們可以看到,這5個div可以左右的切換,每次切換時總會有一個在中間顯眼的位置進(jìn)行展示。在切換時,看起來是div進(jìn)行了移動,進(jìn)行了DOM的增刪操作。但是如果審查下元素,就能看到,DOM元素沒有變換位置,它依然在那個位置,我們只是切換了每個元素上的class,于是頁面上的位置看起來是發(fā)生了變化。
其實(shí)原理就是這樣的: 不進(jìn)行DOM的增刪,為每個位置上的div都寫上特定的樣式,每個div都進(jìn)行絕對定位,然后進(jìn)行樣式的輪播。 每次切換都有個0.6s過渡過程:
-webkit-transition: all 0.6s; transition: all 0.6s;
比如從左往右的class分別為:item_0, item_1, item_cur, item_3, item_4,每個class都是當(dāng)前所在div的定位,向左滑動時,右邊的div會切換到中間,這樣class從左往右就變成了item_1, item_cur, item_3, item_4, item_0。
var egg_change = function(type){ var $demo = $('.demo'), index = parseInt( $demo.attr('index_cur')||2 ), $item = $('.demo .item'), len = $item.length; if( type=='left' ){ index = (index+1)%len; }else{ index = (index-1+len)%len; } $demo.attr('index_cur', index); $item.removeClass('item_0 item_1 item_3 item_4 item_cur'); $item.eq( (index-2+len)%len ).addClass('item_0'); $item.eq( (index-1+len)%len ).addClass('item_1'); $item.eq(index).addClass('item_cur'); $item.eq( (index+1)%len ).addClass('item_3'); $item.eq( (index+2)%len ).addClass('item_4'); }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript中mouseover、mouseout使用詳解
這篇文章主要介紹了javascript中mouseover、mouseout使用詳解的相關(guān)資料,需要的朋友可以參考下2015-07-07javascript實(shí)現(xiàn)點(diǎn)擊按鈕切換圖片
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)點(diǎn)擊按鈕切換圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08Javascript本地存儲localStorage看這一篇就夠了
這篇文章主要給大家介紹了關(guān)于Javascript本地存儲localStorage的相關(guān)資料,localStorage會可以將第一次請求的數(shù)據(jù)直接存儲到本地,這個相當(dāng)于一個5M大小的針對于前端頁面的數(shù)據(jù)庫,需要的朋友可以參考下2024-07-07js使用for循環(huán)及if語句判斷多個一樣的name
這篇文章主要介紹了js使用for循環(huán)機(jī)if語句判斷多個一樣的name,此法比較實(shí)用,需要的朋友可以參考下2014-09-09window.location.href中url中數(shù)據(jù)量太大時的解決方法
這篇文章主要為大家介紹下window.location.href中url中數(shù)據(jù)量太大時的解決方法,需要的朋友可以參考下2013-12-12avalonjs實(shí)現(xiàn)仿微博的圖片拖動特效
JavaScript實(shí)現(xiàn)仿微博的圖片拖動特效,貌似這些天有不少朋友需要這功能,今天發(fā)現(xiàn)這款是js制作的好,不敢獨(dú)享,希望需要的朋友喜歡哦。2015-05-05