国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

利用Js+Css實現折紙動態導航效果實例源碼

2019-11-19 17:47:18
字體:
來源:轉載
供稿:網友

先來看看第一種實現方式

效果圖如下:

不再采用ul li的布局方式

-webkit-transform-style:preserve-3d只對子元素有作用,所以每個div都加。

實例源碼

<!doctype html><html><head><meta charset="utf-8"><title>無標題文檔</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>

第二種實現方式

效果圖如下:

這個原先是隱藏的,點擊后才展開。

通過關鍵幀控制每個div的展開狀態,當要展開的時候給每個div添加className,但是這個className不是一下子全部添加上去的,而是有延時的,所以用到了定時器。

實例源碼

<!doctype html><html><head><meta charset="utf-8"><title>無標題文檔</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>標題</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>

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 友谊县| 仁寿县| 宝鸡市| 萨迦县| 玉溪市| 鄯善县| 靖安县| 黑山县| 确山县| 资阳市| 淳化县| 永吉县| 松溪县| 台前县| 内乡县| 新乡县| 旌德县| 仙居县| 沿河| 泸溪县| 昌乐县| 永善县| 从江县| 洛阳市| 凤庆县| 大邑县| 海原县| 临西县| 临沂市| 九龙县| 岳阳县| 蒲江县| 晋江市| 铁力市| 望都县| 扶绥县| 芦溪县| 潼南县| 长乐市| 兴城市| 阿勒泰市|