摘要:jquery实现垂直展开二级菜单

最近新开发一个简单项目,用到左侧两级的菜单。找找了手头的文件,竟然没有现成的代码,算了,去网上找找整理下吧。

注:jquery-1.8.3.min.js需要下载文件放到同级名为js的文件夹里。

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>jquery垂直展开折叠手风琴效果</title>
<script type="text/javascript" src="js/jquery-1.8.3.min.js"></script>
<style type="text/css">
body {
margin: 0px;
padding: 0px;
font-family: "微软雅黑";
font-size: 12px;
} div, ul, li, ol, dl, dt, dd, img, p, h1, h2, h3, p, table, td, th {
margin: 0px;
padding: 0px;
list-style-type: none;
border: 0;
} a {
text-decoration: none;
} /* 侧导航 */
.menu {
width: 195px;
background-color: #cfe5ec;
} .menu ul {
width: 195px;
padding-top: 5px;
} .menu li {
background: #3E8ED5;
line-height: 30px;
color: #4f4f4f;
display: block;
text-indent: 3em;
margin-top: 1px;
} .menu li a {
height: 30px;
display: block;
color: white;
} .menu li a:hover {
height: 30px;
display: block;
color: #4f4f4f;
} .cur {
background: #2668cb;
font-weight: bold;
}
.submenu {
font-size: 12px;
} .submenu li {
height:30px;
line-height:30px;
background: #48A1F0;
} .submenu a {
display: block;
text-decoration: none;
color: #d9d9d9;
-webkit-transition: all 0.25s ease;
-o-transition: all 0.25s ease;
transition: all 0.25s ease;
} .submenu a:hover {
background: #2668cb;
color: #FFF;
}
</style> </head>
<body>
<div>
<ul class="menu" id="ulmenu">
<li>
<a>开发语言</a>
<ul class="submenu">
<li><a onclick="changeStyle(1);" sysId="1" href="#" >Java</a></li>
<li><a onclick="changeStyle(2);" sysId="2" href="#" >NET</a></li>
<li><a onclick="changeStyle(3);" sysId="3" href="#" >VB</a></li>
<li><a onclick="changeStyle(4);" sysId="4" href="#" >C++</a></li>
</ul>
</li> <li>
<a>集成开发环境</a>
<ul class="submenu">
<li><a onclick="changeStyle(5);" sysId="5" href="#" >WebStrom</a></li>
<li><a onclick="changeStyle(6);" sysId="6" href="#" >Visual studio</a></li>
</ul>
</li>
<li>
<a>脚本语言</a>
<ul class="submenu">
<li><a onclick="changeStyle(7);" sysId="7" href="#">Javascript</a></li>
<li><a onclick="changeStyle(8);" sysId="8" href="#">Python</a></li>
</ul>
</li>
</ul>
</div>
</body>
<script type="text/javascript">
$(function () {
$('.menu li > .submenu').slideUp('normal');//通过使用滑动效果,隐藏被选元素,如果元素已显示出来的话 var accordion_head = $('.menu > li > a'),
accordion_body = $('.menu li > .submenu');
//accordion_head.first().addClass('active').next().slideDown('normal');这行代码设置页面打开时展开第一个菜单
accordion_head.on('click', function (event) {
event.preventDefault();//preventDefault() 方法阻止元素发生默认的行为
if ($(this).attr('class') != 'active') {
accordion_body.slideUp('normal');
$(this).next().stop(true, true).slideToggle('normal');
//获取.menu > li > a > 点击元素的同级的下个元素>停止所有在该元素上正在运行的动画>通过使用滑动效果在显示和隐藏状态之间切换元素
accordion_head.removeClass('active');
$(this).addClass('active');
}
else {
accordion_body.slideUp('normal');
$(this).removeClass('active');
}
});
}); function changeStyle(obj) {
$(".submenu a").each(function () {
if (obj == $(this).attr("sysId")) {
$(this).addClass('cur');
} else {
$(this).removeClass('cur');
}
});
} </script>
</html>

样式active用来标记当前哪个元素是展开状态,主要用到jQuery里的slideUp和 slideToggle方法。

jquery垂直展开折叠手风琴二级菜单的更多相关文章

  1. jQuery - 制作点击显示二级菜单效果

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

  2. jquery导航栏高亮(二级菜单点击一级保持高亮)

    <script type="text/javascript"> var urlstr = location.href; var urlstatus=false; $(& ...

  3. python 全栈开发,Day109(客户管理之动态"二级"菜单)

    昨日内容回顾 1. 权限有几张表? 2. 简述权限流程? 3. 为什么要把权限放入session? 4. 静态文件和模块文件 5. 相关技术点 - orm查询 - 去空 - 去重 - 中间件 - in ...

  4. 使用jQuery 中的显示与隐藏动画效果实现折叠下拉菜单的收缩和展开,在页面的列表中有若干项,列表的每项中有一个二级列表,二级列表默认为隐藏状态。点击列表的项,切换二级列表的显示或隐藏状态

    查看本章节 查看作业目录 需求说明: 使用jQuery 中的显示与隐藏动画效果实现折叠下拉菜单的收缩和展开,在页面的列表中有若干项,列表的每项中有一个二级列表,二级列表默认为隐藏状态.点击列表的项,切 ...

  5. Jquery垂直下拉二级菜单

    自己做了一个基于Jquery 的垂直下拉二级菜单功能,直接看图: Html的代码如下: <!DOCTYPE html> <html> <head> <meta ...

  6. jquery 展开折叠菜单

    jquery 展开折叠菜单 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <ht ...

  7. jQuery垂直二级导航菜单代码

    http://www.sucaihuo.com/js/395.html 分享一个简单的垂直二级菜单导航.   HTML <div id="my_menu" class=&qu ...

  8. bootstrap-简单实用的垂直手风琴滑动菜单列表特效

    前端: <html lang="zh"> <head> <meta charset="UTF-8"> <meta ht ...

  9. 基于jQuery垂直多级导航菜单代码

    基于jQuery垂直多级导航菜单代码是一款黑色风格的jQuery竖直导航菜单特效下载.效果图如下: 在线预览   源码下载 实现的代码. html代码: <ul class="ce&q ...

随机推荐

  1. C#winform中使用控件的Dock属性进行布局

    想要实现如下布局,可以通过设置控件的Dock属性达到效果 1.拖放一个panel控件一个label控件(放在panel中)和一个treeView控件到TestForm中 2.设置panel的Dock属 ...

  2. 固定某一元素在某一位置 jquery

    方法: $(window).scroll(function (){}) 属性: 滚动变化值 $(window).scrollTop();$(window).scrollLeft(); 需要结合的样式: ...

  3. JQuery..bind命名空间

    先看手册,由于bind方法有三个参数(type,[data],fn),所以手册上这么介绍: .bind() 方法是用于往文档上附加行为的主要方式.所有JavaScript事件对象, 比如focus, ...

  4. mysql创建外键出错(注意数据库表字段排序)

    1.  两个字段的类型或者大小不严格匹配.例如,如果一个是int(10),那么外键也必须设置成int(10),而不是int(11),也不能是tinyint.另外,你还必须确定两个字段是否一个为 sig ...

  5. GDB多线程调试

    一.多线程调试1. 多线程调试,最重要的几个命令:info threads                        查看当前进程的线程.                              ...

  6. 实验一补充内容 Java开发环境的熟悉-刘蔚然

    本次实验 PSP时间统计 步骤 耗时百分比 需求分析 5% 设计 10% 代码实现 67% 测试 15% 分析总结 3%

  7. js获取div中的文本框数据

    通过div得到div里的所有数据 大神的世界无需解释,当然不是说我,当我看到这些代码的时候我惊呆了! 这是一个工具方法js: js: /* * 获取指定对象下的所有input.textarea值 * ...

  8. [LeetCode]题解(python):051-N-Queens

    题目来源 https://leetcode.com/problems/n-queens/ The n-queens puzzle is the problem of placing n queens ...

  9. 学习一下Fiddler的强大

    ①引言:Fiddler (中文名称:小提琴)是一个 HTTP 的调试代理,以代理服务器的方式,监听系统的Http网络数据流动, Fiddler 可以也可以让你检查所有的 HTTP 通讯,设置断点,以及 ...

  10. SQL Server 用SQL语句查找某个表的触发器

    select   *   from   sysobjects   where   xtype='TR'   and   parent_obj=object_id('表名') 再用sp_helptext ...