利用Js+Css實現(xiàn)折紙動態(tài)導(dǎo)航效果實例源碼
先來看看第一種實現(xiàn)方式
效果圖如下:
不再采用ul li的布局方式
-webkit-transform-style:preserve-3d
只對子元素有作用,所以每個div都加。
實例源碼
<!doctype html> <html> <head> <meta charset="utf-8"> <title>無標(biāo)題文檔</title> <style> .wrap{margin:30px auto;width:302px;-webkit-perspective:800px; -webkit-transform-style:preserve-3d; position:relative;} .wrap div{ position:absolute; top:52px;left:0;-webkit-transform-style:preserve-3d; -webkit-transform-origin:top;} .wrap span{ display:block;width:300px;border:1px solid #000;height:50px; font:16px/50px "宋體"; background:#ccc;} </style> </head> <body> <input type="button" value="展開" /> <input type="button" value="收縮" /> <div class="wrap" id="list"> <span>第一項</span> <div> <span>第二項</span> <div> <span>第三項</span> <div> <span>第四項</span> <div> <span>第五項</span> <div> <span>第六項</span> <div> <span>第七項</span> </div> </div> </div> </div> </div> </div> </div> <script> window.onload=function() { var oList=document.getElementById("list"); var aDiv=oList.getElementsByTagName("div"); var aBtn=document.getElementsByTagName("input"); aBtn[1].onclick=function() { for(var i=0;i<aDiv.length;i++) { aDiv[i].style.transition="0.5s "+(aDiv.length-i)*100+"ms"; aDiv[i].style.WebkitTransform="rotateX(60deg)"; } }; aBtn[0].onclick=function() { for(var i=0;i<aDiv.length;i++) { aDiv[i].style.transition="0.5s "+i*100+"ms"; aDiv[i].style.WebkitTransform="rotateX(0deg)"; } }; }; </script> </body> </html>
第二種實現(xiàn)方式
效果圖如下:
這個原先是隱藏的,點擊后才展開。
通過關(guān)鍵幀控制每個div的展開狀態(tài),當(dāng)要展開的時候給每個div添加className
,但是這個className
不是一下子全部添加上去的,而是有延時的,所以用到了定時器。
實例源碼
<!doctype html> <html> <head> <meta charset="utf-8"> <title>無標(biāo)題文檔</title> <style> @-webkit-keyframes open{ 0% { -webkit-transform:rotateX(-120deg); } 40% { -webkit-transform:rotateX(30deg); } 60% { -webkit-transform:rotateX(-20deg); } 80% { -webkit-transform:rotateX(10deg); } 100% { -webkit-transform:rotateX(0deg); } } .wrap{margin:30px auto;width:300px;-webkit-perspective:800px;position:relative;} .wrap h2{ height:50px;background:#F03; text-align:center; font:16px/50px "微軟雅黑"; color:#fff; position:relative;z-index:2;} .wrap div{ position:absolute; top:32px;left:0;-webkit-transform-style:preserve-3d; -webkit-transform-origin:top; -webkit-transform:rotateX(-120deg); transition:.5s;} .wrap>div{ top:50px;} .wrap .open{-webkit-animation:open 2s;-webkit-transform:rotateX(0deg);} .wrap span{ display:block;width:300px;height:30px; font:14px/30px "宋體"; background:#6F3; text-indent:15px; color:#fff; transition:.5s; box-shadow:inset 0 0 30px 20px rgba(0,0,0,1);} .wrap .open>span{box-shadow:inset 0 0 30px 10px rgba(0,0,0,0);} .wrap span:hover{ background:#FF0;text-indent:30px;} </style> </head> <body> <input type="button" value="展開" /> <input type="button" value="收縮" /> <div class="wrap" id="list"> <h2>標(biāo)題</h2> <div> <span>第一項</span> <div> <span>第二項</span> <div> <span>第三項</span> <div> <span>第四項</span> <div> <span>第五項</span> <div> <span>第六項</span> <div> <span>第七項</span> </div> </div> </div> </div> </div> </div> </div> </div> <script> window.onload=function() { var oList=document.getElementById("list"); var aDiv=oList.getElementsByTagName("div"); var aBtn=document.getElementsByTagName("input"); var oTimer=null; aBtn[1].onclick=function() { var i=aDiv.length-1; clearInterval(oTimer); oTimer=setInterval(function(){ aDiv[i].className=""; i--; if(i<0) { clearInterval(oTimer); } },50); }; aBtn[0].onclick=function() { var i=0; clearInterval(oTimer); oTimer=setInterval(function(){ aDiv[i].className="open"; i++; if(i==aDiv.length) { clearInterval(oTimer); } },200); }; }; </script> </body> </html>
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
詳解bootstrap的modal-remote兩種加載方式【強(qiáng)化】
本篇文章主要介紹了詳解bootstrap的modal-remote兩種加載方式【強(qiáng)化】,具有一定的參考價值,有興趣的可以了解一下。2017-01-01JavaScript中動態(tài)向表格添加數(shù)據(jù)
本文給大家分享使用原生javascript實現(xiàn)動態(tài)向表格中添加數(shù)據(jù)的方法,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧2017-01-01使用純javascript實現(xiàn)經(jīng)典掃雷游戲
本文給大家分享的是個人剛開始學(xué)習(xí)javascript的時候?qū)懙姆聎indows經(jīng)典的掃雷游戲的代碼,當(dāng)時只是寫了下來,沒加注釋,這里補(bǔ)上,有需要的小伙伴可以參考下。2015-04-04js中對函數(shù)設(shè)置默認(rèn)參數(shù)值的3種方法
這篇文章主要介紹了js中對函數(shù)設(shè)置默認(rèn)參數(shù)值的3種方法嗎,3種方法都具有一定的參考價值,感興趣的小伙伴們可以參考一下2015-10-10