欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用Js+Css實現(xiàn)折紙動態(tài)導(dǎo)航效果實例源碼

 更新時間:2017年01月25日 09:55:33   投稿:daisy  
這篇文章主要給大家介紹了利用Js+Css實現(xiàn)折紙動態(tài)導(dǎo)航的效果,實現(xiàn)后的效果非常不錯,文中給出了簡單的介紹和完整的實例代碼,對大家具有一定的參考價值,有需要的朋友們下面來一起看看吧。

先來看看第一種實現(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)文章

  • javascript操作元素的常見方法小結(jié)

    javascript操作元素的常見方法小結(jié)

    這篇文章主要介紹了javascript操作元素的常見方法,結(jié)合實例形式總結(jié)分析了JavaScript針對頁面元素動態(tài)獲取、賦值、動態(tài)操作相關(guān)使用技巧,需要的朋友可以參考下
    2019-11-11
  • 關(guān)于JavaScript的單雙引號嵌套問題

    關(guān)于JavaScript的單雙引號嵌套問題

    單引號和雙引號之間可以相互嵌套。接下來通過本文給大家介紹JavaScript的單雙引號嵌套問題 ,感興趣的朋友一起看看吧
    2017-08-08
  • js獲取滾動距離的方法

    js獲取滾動距離的方法

    這篇文章主要介紹了js獲取滾動距離的方法,涉及javascript針對頁面滾動條的相關(guān)操作技巧,需要的朋友可以參考下
    2015-05-05
  • 關(guān)于js的事件循環(huán)機(jī)制剖析

    關(guān)于js的事件循環(huán)機(jī)制剖析

    JS事件循環(huán)機(jī)制,最常用到的地方應(yīng)該是做面試題,經(jīng)常給出一段代碼,讓你寫出console.log()順序,下面這篇文章主要給大家介紹了關(guān)于js事件循環(huán)機(jī)制的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • 詳解bootstrap的modal-remote兩種加載方式【強(qiáng)化】

    詳解bootstrap的modal-remote兩種加載方式【強(qiáng)化】

    本篇文章主要介紹了詳解bootstrap的modal-remote兩種加載方式【強(qiáng)化】,具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01
  • js實現(xiàn)九宮格圖片半透明漸顯特效的方法

    js實現(xiàn)九宮格圖片半透明漸顯特效的方法

    這篇文章主要介紹了js實現(xiàn)九宮格圖片半透明漸顯特效的方法,涉及js操作css特效的技巧,非常具有實用價值,需要的朋友可以參考下
    2015-02-02
  • JavaScript中動態(tài)向表格添加數(shù)據(jù)

    JavaScript中動態(tài)向表格添加數(shù)據(jù)

    本文給大家分享使用原生javascript實現(xiàn)動態(tài)向表格中添加數(shù)據(jù)的方法,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的的朋友參考下吧
    2017-01-01
  • 使用純javascript實現(xiàn)經(jīng)典掃雷游戲

    使用純javascript實現(xiàn)經(jīng)典掃雷游戲

    本文給大家分享的是個人剛開始學(xué)習(xí)javascript的時候?qū)懙姆聎indows經(jīng)典的掃雷游戲的代碼,當(dāng)時只是寫了下來,沒加注釋,這里補(bǔ)上,有需要的小伙伴可以參考下。
    2015-04-04
  • js中對函數(shù)設(shè)置默認(rèn)參數(shù)值的3種方法

    js中對函數(shù)設(shè)置默認(rèn)參數(shù)值的3種方法

    這篇文章主要介紹了js中對函數(shù)設(shè)置默認(rèn)參數(shù)值的3種方法嗎,3種方法都具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2015-10-10
  • js日期格式化yyyy-MM-dd問題

    js日期格式化yyyy-MM-dd問題

    這篇文章主要介紹了js日期格式化yyyy-MM-dd問題,具有很好的參考價值,希望對大家大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01

最新評論