用javascript实现简单的下拉折叠菜单效果

实现步骤

  (a)获得各操作的dom对象;

  (b)在所有菜单按钮对象上添加单击事件;

  (c)设置所有菜单按钮样式为空,并将当前按钮的样式设置为“active”;同时设置div1下面的所有div元素的display为none,并将当前按钮所对应的div的display为block

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Gary_js实现简单的下拉折叠菜单</title>
<style>
* {margin:0px; padding:0px;}
#div1 {width:200px; margin: auto; line-height:25px;}
ul {list-style:none;}
li {background:#ccc;margin-bottom:3px;}
dl {background:#eee; display:none;}
.active {background:#F90;}
</style>
<script>
//此处编写js代码,实现简单的下拉折叠菜单,默认菜单1是展开的 </script>
</head> <body>
<div id="div1">
<ul id="menu">
<li class="active">菜单1</li>
<dl style="display:block;">
<dd>菜单1.</dd>
<dd>菜单1.</dd>
<dd>菜单1.</dd>
<dd>菜单1.</dd>
</dl>
<li>菜单2</li>
<dl>
<dd>菜单2.</dd>
<dd>菜单2.</dd>
<dd>菜单2.</dd>
<dd>菜单2.</dd>
</dl>
<li>菜单3</li>
<dl>
<dd>菜单3.</dd>
<dd>菜单3.</dd>
<dd>菜单3.</dd>
<dd>菜单3.</dd>
</dl>
</ul>
</div>
</body>
</html>

效果一

  点击一级菜单时弹出二级子菜单,不需要对菜单进行 display==“none”?true:false 判断(缺点:无法把三个一级菜单状态都设置为"display")

    window.onload = function () {
var lis = document.getElementsByTagName('li');
var dls = document.getElementsByTagName('dl');
for (var i = ; i < lis.length; i ++) {
lis[i].index = i;
lis[i].onclick = function () {
for (var i = ; i < lis.length; i ++) {
lis[i].className ='';
dls[i].style.display = 'none';
}
this.className = 'active';
dls[this.index].style.display = 'block';
}
}
}

Gary.Script

效果二

  点击一级菜单弹时进行display==“none”?true:false 使二级菜单实现点击收缩功能

<script>
//此处编写js代码,实现简单的下拉折叠菜单,默认菜单1是展开的
window.onload = function () {
var lis = document.getElementsByTagName('li');
var dls = document.getElementsByTagName('dl');
for (var i = ; i < lis.length; i ++) {
lis[i].index = i;
lis[i].onclick = function () {
for (var i = ; i < lis.length; i ++) {
lis[i].className ='';
}
this.className = 'active';
if(dls[this.index].style.display == 'block')
dls[this.index].style.display = 'none'
else
dls[this.index].style.display = 'block'
}
}
}
</script>

Gary.Script

效果三

   通过animate.css 添加实现二级子菜单动画展开动画

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>Gary_js实现简单的下拉折叠菜单</title>
<style>
* {margin:0px; padding:0px;}
#div1 {width:200px; margin:0 auto; line-height:25px;}
ul {list-style:none;}
li {background:#ccc;margin-bottom:3px;}
dl {background:#eee;display:none;
transform-origin:50% 0;
-webkit-animation:gary .5s ease-in;
transition: all .3s infinite;}
.active {background:#F90;}
@-webkit-keyframes gary{
0%{transform:scale(1,0);}
25%{transform:scale(1,1.2);}
50%{transform:scale(1,0.85);}
75%{transform:scale(1,1.05);}
100%{transform:scale(1,1);}
} </style>
<script>
//此处编写js代码,实现简单的下拉折叠菜单,默认菜单1是展开的
window.onload = function () {
var lis = document.getElementsByTagName('li');
var dls = document.getElementsByTagName('dl');
for (var i = 0; i < lis.length; i ++) {
lis[i].index = i;
lis[i].onclick = function () {
for (var i = 0; i < lis.length; i ++) {
lis[i].className ='';
}
this.className = 'active';
if(dls[this.index].style.display == 'block')
dls[this.index].style.display = 'none'
else
dls[this.index].style.display = 'block'
}
}
}
</script>
</head> <body>
<div id="div1">
<ul id="menu">
<li class="active">菜单1</li>
<dl style="display:block;">
<dd>菜单1.1</dd>
<dd>菜单1.2</dd>
<dd>菜单1.3</dd>
<dd>菜单1.4</dd>
</dl>
<li>菜单2</li>
<dl>
<dd>菜单2.1</dd>
<dd>菜单2.2</dd>
<dd>菜单2.3</dd>
<dd>菜单2.4</dd>
</dl>
<li>菜单3</li>
<dl>
<dd>菜单3.1</dd>
<dd>菜单3.2</dd>
<dd>菜单3.3</dd>
<dd>菜单3.4</dd>
</dl>
</ul>
</div>
</body>
</html>

Gary.Html

动画实现原理

@keyframes创建动画  传送门

  创建动画是通过逐步改变从一个CSS样式设定到另一个。

  在动画过程中,您可以更改CSS样式的设定多次。

  指定的变化时发生时使用%,或关键字"from"和"to",这是和0%到100%相同。
  0%是开头动画,100%是当动画完成。
  为了获得最佳的浏览器支持,您应该始终定义为0%和100%的选择器。

 

 

transform-origin 属性:改变被转换元素的位置  传送门

  

transform-origin: x-axis y-axis z-axis;

animation 属性:将动画与 div 元素绑定  传送门

animation: name duration timing-function delay iteration-count direction;

transition-timing-function 属性  传送门

transition-timing-function: linear|ease|ease-in|ease-out|ease-in-out|cubic-
bezier(n,n,n,n);
linear 规定以相同速度开始至结束的过渡效果(等于 cubic-bezier(0,0,1,1))。
ease 规定慢速开始,然后变快,然后慢速结束的过渡效果(cubic-bezier(0.25,0.1,0.25,1))。
ease-in 规定以慢速开始的过渡效果(等于 cubic-bezier(0.42,0,1,1))。
ease-out 规定以慢速结束的过渡效果(等于 cubic-bezier(0,0,0.58,1))。
ease-in-out 规定以慢速开始和结束的过渡效果(等于 cubic-bezier(0.42,0,0.58,1))。
cubic-bezier(n,n,n,n) 在 cubic-bezier 函数中定义自己的值。可能的值是 0 至 1 之间的数值。

==================================分割线

  H5页面运行时使用console.log()在控制台查看点击标签下标

<script>
//此处编写js代码,实现简单的下拉折叠菜单,默认菜单1是展开的
window.onload = function () {
var lis = document.getElementsByTagName('li');
var dls = document.getElementsByTagName('dl'); for (var i = 0; i < lis.length; i ++) {
lis[i].index = i;
lis[i].onclick = function () {
//清空所有的样式
for (var i = 0; i < lis.length; i ++) {
lis[i].className ='';
} this.className = 'active';
if(dls[this.index].style.display == 'block')
dls[this.index].style.display = 'none'
else
dls[this.index].style.display = 'block' console.log(this.index)
console.log(i)
}
}
}
</script>

  

  可以看到,若果不使用lis[i].index = i去得到元素下标,那么i会不断指向数组元素最大值的下一个值!!!

    //贪心的想在控制台上获得更多的信息
console.log(dls[this.index])

原生Js_实现简单的下拉折叠菜单(添加弹出动画效果)的更多相关文章

  1. 在 jQuery 中使用滑入滑出动画效果,实现二级下拉导航菜单的显示与隐藏效果

    查看本章节 查看作业目录 需求说明: 在 jQuery 中使用滑入滑出动画效果,实现二级下拉导航菜单的显示与隐藏效果 用户将光标移动到"最新动态页"或"帮助查询" ...

  2. 原生js实现简单的下拉刷新功能

    前言: 我们在浏览移动端web页面的时候,经常会用到下拉刷新. 现在我们用原生的js实现这个非常简单的下拉刷新功能. (温馨提示:本文比较基础,功能也很简单.写的不好的地方,希望大神提点一二.) 一. ...

  3. ALV屏幕捕捉回车及下拉框事件&ALV弹出框回车及下拉框事件

    示例展示: 屏幕依据输入的物料编码或下拉框物料编码拍回车自动带出物料描述: 点击弹出框,输入物料编码拍回车带出物料描述,点击确认,更新ALV: 1.创建屏幕9000,用于处理ALV弹出框: 2.针对屏 ...

  4. 原生js实现简单的下拉加载

    #获取当前滚动条的高度document.documentElement.scrollTop #获取当前窗口的高度 document.documentElement.clientHeight #获取当前 ...

  5. Javascript实现简单的下拉二级菜单

    在线演示;http://jsfiddle.net/Web_Code/ThhbG/embedded/result/ <span style="font-size:14px;"& ...

  6. CSS3 3D下拉折叠菜单

    在线演示 本地下载

  7. JQuery -&gt; 超级简单的下拉菜单

    使用jquery实现一个超级简单的下拉菜单. 效果图 最初的效果 watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvRmVlTGFuZw==/font/5a6L ...

  8. Example017简单的下拉框

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 在AJAX里 使用【 XML 】 返回数据类型 实现简单的下拉菜单数据

    在AJAX里 使用XML返回数据类型 实现简单的下拉菜单数据 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN ...

随机推荐

  1. JAVA基础:接口

    接口声明: interface 接口名 实现接口: class 类名 implements 接口名 接口特点: 1. 接口中的成员变量默认都是public.static.final类型的,必须被显式初 ...

  2. 如何不用 transition 和 animation 也能做网页动画

    效果预览 在线演示 按下右侧的"点击预览"按钮可以在当前页面预览,点击链接可以全屏预览. https://codepen.io/comehope/pen/BxbQJj 可交互视频教 ...

  3. oa_mvc_easyui_分页(4)

    1.数据层的编写 NewListInfoDal.cs: GetPageEntityList方法,根据start,end取出数据 --row_number() over()函数查询 LoadEntity ...

  4. JAVA网络编程入门

    JAVA网络编程入门 软件结构 C/S结构 B/S结构 无论哪一种结构,都离不开网络的支持.网络编程,就是在网络的条件下实现机器间的通信的过程 网络通信协议 网络通信协议:通信双方必须同时遵守才能完成 ...

  5. luogu P3226 [HNOI2012]集合选数

    luogu 因为限制关系只和2和3有关,如果把数中2的因子和3的因子都除掉,那剩下的数不同的数是不会相互影响,所以每次考虑剩下的数一样的一类数,答案为每类数答案的乘积 如果选了一个数,那么2的因子多1 ...

  6. 订单支付倒计时-剩余时间xx小时xx分xx秒

    //<input type="hidden" id="endTime" value="1554912000000"> 结束时间 ...

  7. Vue 路由拦截(对某些页面需要登陆才能访问)

    前言 做项目的时候有个需求,就是发现没有登录,竟然也可以进入我的主页,这样肯定是不能容忍的.于是就要让他进入主页的时候,加个判断是否有登录,若没有登录,则返回登录界面,登录成功后还可以跳转到之前进入的 ...

  8. vue中监听数据变化 watch

    今天做项目的时候,子组件中数据(原本固定的数据)需要父组件动态传入,如果一开始初始化用到的数据.但当时还没有获取到,初始化结束就不会更新数据了.只有监听这两个属性,再重新执行初始化. 1.watch是 ...

  9. bagging and boosting

    bagging 侧重于降低方差 方差-variance 方差描述的是预测值的变化范围,离散程度,也就是离期真实值的距离.方差过大表现为过拟合,训练数据的预测f-score很高,但是验证或测试数据的预测 ...

  10. python爬去虎扑数据信息,完成可视化

    首先分析虎扑页面数据 如图我们所有需要的数据都在其中![image.png](1)所以我们获取需要的内容直接利用beaitifulsoupui4``` soup.find_all('a',class_ ...