jQuery创建折叠式菜单


Posted in jQuery onJune 15, 2019

今天给大家介绍如何使用jQuery创建折叠式菜单,即通常所说的手风琴效果(accordion [əˈkɔ:rdiən])。

实现效果如下:

jQuery创建折叠式菜单

一、HTML代码结构

要实现折叠式菜单,代码相当简单,如下所示:

<ul class="accordion">
 <li class="selected">
  <span>北京景点</span>
  <div>
  <ul>
   <li>故宫</li>
   <li>十三陵</li>
   <li>圆明园</li>
   <li>长城</li>
  </ul>
  </div>
 </li>
 <li>
  <span>上海景点</span>
  <div>
  <ul>
   <li>东方明珠</li>
   <li>外滩</li>
   <li>豫园</li>
   <li>龙华寺</li>
  </ul>
  </div>
 </li>
 <li>
  <span>广州景点</span>
  <div>
  <ul>
   <li>白云山</li>
   <li>中山纪念堂</li>
   <li>华南植物园</li>
   <li>越秀公园</li>
  </ul>
  </div>
 </li>
 <li>
  <span>深圳景点</span>
  <div>
  <ul>
   <li>世界之窗</li>
   <li>东门老街</li>
   <li>海上田园旅游区</li>
   <li>中信明思克航母</li>
  </ul>
  </div>
 </li>
 <li>
  <span>厦门景点</span>
  <div>
  <ul>
   <li>鼓浪屿</li>
   <li>集美嘉庚园</li>
   <li>万石植物园</li>
   <li>方特梦幻王国</li>
  </ul>
  </div>
 </li>
</ul>

整个折叠式菜单是一个无序列表,每个菜单项是一个li。在li中,有一个span用于标题,一个div中包含了另外一个无序列表,用于子菜单。

二、jQuery代码分析

jQuery的代码也很简单,只有短短的几行:

$(function () {
  $("ul.accordion li span").on('click', function () {
  $(this).parent().siblings().removeClass('selected').find('div').hide();
  $(this).parent().addClass('selected');
  $(this).next().slideDown(500);
  });
 });

我们来分析一下。

首先,通过jQuery的选择器"ul.accordion li span"指定在菜单项的标题上点击,可以折叠菜单。

click事件处理函数的第一行代码做了两件事,一个是将其它菜单项的selected样式移除,另一个是将其它菜单项的div(包括其中的子菜单)隐藏起来。$(this).parent即span的上一级,即li。.siblings()查找它的兄弟元素,并使用链式调用首先移除其selected样式,再查找其中的div并隐藏。

第二行代码为当前点击菜单添加selected样式。

第三行代码展开当前菜单的子菜单。$(this).next()即span的下一个元素,即div(其中包含子菜单)。.slideDown(500)将子菜单向下缓缓展开,使用了CSS的动画效果,500指定动画时间为500毫秒。

三、CSS代码分析

这个折叠菜单的HTML代码和jQuery代码本身都相当简单,但CSS代码相对较长:

<style>
 body {
  font-family: Verdana, Arial, Helvetica, sans-serif;
 }
 
 .accordion,
 .accordion ul { /* 折叠菜单及其子菜单的通用样式 */
  font-size: 14px;
  font-weight: bold;
  width: 300px;
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: center;
  border: 5px solid #343b42;
 }
 
 .accordion ul {
  border: 0;
 }
 
 .accordion ul li { /* 子菜单的菜单项样式 */
  line-height: 50px;
  height: 50px;
  color: #e6efee;
  border-bottom: 1px solid #383b4c;
  background-color: #282b3a;
 }
 
 .accordion li span { /* 折叠菜单的标题样式 */
  line-height: 60px;
  display: block;
  height: 60px;
  color: #e6efee;
  border: 2px solid #343b42;
  background-color: #3789d3;
 }
 
 .accordion li.selected span { /* 折叠菜单选中项的标题样式 */
  color: #e6efee;
  background-color: #393c4b;
 }
 
 .accordion li div { /* 子菜单平时不显示 */
  display: none;
 }
 
 .accordion li.selected div { /* 添加了selected样式时才显示 */
  display: block;
 }
</style>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jQuery Validate表单验证插件实现代码
Jun 08 jQuery
jQuery的时间datetime控件在AngularJs中的使用实例(分享)
Aug 17 jQuery
jquery操作ul的一些操作笔记整理(干货)
Aug 31 jQuery
jQuery实现判断上传图片类型和大小的方法示例
Apr 11 jQuery
jQuery判断自定义属性data-val用法示例
Jan 07 jQuery
jquery无缝图片轮播组件封装
Nov 25 jQuery
jQuery实现文本显示一段时间后隐藏的方法分析
Jun 20 jQuery
jQuery删除/清空指定元素的所有子节点实例代码
Jul 04 jQuery
jQuery中DOM操作原则实例分析
Aug 01 jQuery
jQuery模仿ToDoList实现简单的待办事项列表
Dec 30 jQuery
jQuery Datatables 动态列+跨列合并实现代码
Jan 30 jQuery
使用jQuery实现购物车
Oct 29 jQuery
JS实现点击生成UUID的方法完整实例【基于jQuery】
Jun 12 #jQuery
jquery操作checkbox的常用方法总结【附测试源码下载】
Jun 10 #jQuery
基于jquery实现的tab选项卡功能示例【附源码下载】
Jun 10 #jQuery
基于Bootstrap和JQuery实现动态打开和关闭tab页的实例代码
Jun 10 #jQuery
jQuery+ajax实现批量删除功能完整示例
Jun 06 #jQuery
jquery+ajax实现上传图片并显示上传进度功能【附php后台接收】
Jun 06 #jQuery
jQuery操作cookie的示例代码
Jun 05 #jQuery
You might like
php中Smarty模板初体验
2011/08/08 PHP
PHP MSSQL 分页实例
2016/04/13 PHP
jquery与js函数冲突的两种解决方法
2013/09/09 Javascript
Eclipse下jQuery文件报错出现错误提示红叉
2014/01/13 Javascript
一个通过script自定义属性传递配置参数的方法
2014/09/15 Javascript
JavaScript数据类型判定的总结笔记
2015/07/31 Javascript
HTML页面,测试JS对C函数的调用简单实例
2016/08/09 Javascript
javaScript+turn.js实现图书翻页效果实例代码
2017/02/16 Javascript
实例详解display:none与visible:hidden的区别
2017/03/30 Javascript
老生常谈angularjs中的$state.go
2017/04/24 Javascript
JavaScript实现无穷滚动加载数据
2017/05/06 Javascript
深入理解JavaScript和TypeScript中的class
2018/04/22 Javascript
jQuery实现的网站banner图片无缝轮播效果完整实例
2019/01/28 jQuery
微信小程序项目总结之记账小程序功能的实现(包括后端)
2019/08/20 Javascript
解决layui laydate 时间控件一闪而过的问题
2019/09/28 Javascript
手把手教您实现react异步加载高阶组件
2020/04/07 Javascript
JavaScript中layim之整合右键菜单的示例代码
2021/02/06 Javascript
python3图片转换二进制存入mysql
2013/12/06 Python
python批量修改文件名的实现代码
2014/09/01 Python
浅析使用Python操作文件
2017/07/31 Python
Python入门之三角函数全解【收藏】
2017/11/08 Python
pandas ix &amp;iloc &amp;loc的区别
2019/01/10 Python
Python应用领域和就业形势分析总结
2019/05/14 Python
Linux下远程连接Jupyter+pyspark部署教程
2019/06/21 Python
使用Python实现跳一跳自动跳跃功能
2019/07/10 Python
Python 字符串、列表、元组的截取与切片操作示例
2019/09/17 Python
Python 写了个新型冠状病毒疫情传播模拟程序
2020/02/14 Python
如何清空python的变量
2020/07/05 Python
利用css3实现的简单的鼠标悬停按钮
2014/11/04 HTML / CSS
美国销售第一的智能手机和平板电脑保护壳:OtterBox
2017/12/21 全球购物
财务出纳岗位职责
2014/02/03 职场文书
优秀学生干部先进事迹材料
2014/05/26 职场文书
幼儿园见习总结
2015/06/23 职场文书
自荐信大全
2019/03/21 职场文书
小程序教您怎样你零成本推广获取数万用户的方法
2019/07/30 职场文书
Python包管理工具pip的15 个使用小技巧
2021/05/17 Python