全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

利用Js+Css实现折纸动态导航效果实例源码

先来看看第一种实现方式

效果图如下:

不再采用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>

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。


# js如何实现动态导航  # js实现动态导航栏目  # css3  # 3d折纸动画效果  # JS+CSS实现鼠标滑过时动态翻滚的导航条效果  # javascript实现的鼠标悬停时动态翻滚的导航条  # JS实现移动端可折叠导航菜单(现代都市风)  # JS无限级导航菜单实现方法  # vuejs 切换导航条高亮(路由菜单高亮)的方法示例  # js实现水平滚动菜单导航  # 原生JS实现导航下拉菜单效果  # 如何使用wheelnav.js构建酷炫的动态导航菜单  # 宋体  # 无标题文档  # 六项  # 七项  # 第三项  # 第五项  # 第四项  # 是有  # 微软  # 第一项  # 这篇文章  # 后才  # 先来  # 第二种  # 第一种  # 有疑问  # origin  # left  # text  # block 


相关文章: 广州网站设计制作一条龙,广州巨网网络科技有限公司是干什么的?  北京网站制作公司哪家好一点,北京租房网站有哪些?  如何用虚拟主机快速搭建网站?详细步骤解析  济南网站建设制作公司,室内设计网站一般都有哪些功能?  免费网站制作模板下载,除了易企秀之外还有什么H5平台可以制作H5长页面,最好是免费的?  如何登录建站主机?访问步骤全解析  小建面朝正北,A点实际方位是否存在偏差?  常州企业网站制作公司,全国继续教育网怎么登录?  无锡营销型网站制作公司,无锡网选车牌流程?  再谈Python中的字符串与字符编码(推荐)  如何在VPS电脑上快速搭建网站?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  如何在橙子建站中快速调整背景颜色?  ,想在网上投简历,哪几个网站比较好?  独立制作一个网站多少钱,建立网站需要花多少钱?  网站按钮制作软件,如何实现网页中按钮的自动点击?  洛阳网站制作公司有哪些,洛阳的招聘网站都有哪些?  广州商城建站系统开发成本与周期如何控制?  如何快速生成橙子建站落地页链接?  如何在万网自助建站中设置域名及备案?  网站app免费制作软件,能免费看各大网站视频的手机app?  建站之星如何修改网站生成路径?  ,柠檬视频怎样兑换vip?  Python如何创建带属性的XML节点  c++ stringstream用法详解_c++字符串与数字转换利器  建站之星好吗?新手能否轻松上手建站?  北京网页设计制作网站有哪些,继续教育自动播放怎么设置?  如何在IIS中新建站点并配置端口与物理路径?  广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  ,怎么在广州志愿者网站注册?  山东云建站价格为何差异显著?  css网站制作参考文献有哪些,易聊怎么注册?  整人网站在线制作软件,整蛊网站退不出去必须要打我是白痴才能出去?  如何自定义建站之星模板颜色并下载新样式?  建站之星代理如何优化在线客服效率?  青岛网站建设如何选择本地服务器?  七夕网站制作视频,七夕大促活动怎么报名?  如何快速查询网站的真实建站时间?  台州网站建设制作公司,浙江手机无犯罪记录证明怎么开?  如何在阿里云虚拟机上搭建网站?步骤解析与避坑指南  浅析上传头像示例及其注意事项  宝塔建站无法访问?如何排查配置与端口问题?  建站主机服务器选购指南:轻量应用与VPS配置解析  上海网站制作开发公司,上海买房比较好的网站有哪些?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  网站网页制作电话怎么打,怎样安装和使用钉钉软件免费打电话?  官网网站制作腾讯审核要多久,联想路由器newifi官网  制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?  如何选择适配移动端的WAP自助建站平台? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。