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 相关文章推荐
JS jQuery使用正则表达式去空字符的简单实现代码
May 20 jQuery
jQuery动态添加.active 实现导航效果代码思路详解
Aug 29 jQuery
JQuery EasyUI 结合ztrIee的后台页面开发实例
Sep 01 jQuery
jqueryUI tab标签页代码分享
Oct 09 jQuery
利用jQuery+localStorage实现一个简易的计时器示例代码
Dec 25 jQuery
实现jquery放大镜的两种方法
Feb 22 jQuery
jQuery+ajax读取json数据并按照价格排序示例
Mar 28 jQuery
jQuery实现常见的隐藏与展示列表效果示例
Jun 04 jQuery
jQuery插件实现弹性运动完整示例
Jul 07 jQuery
详解jQuery如何实现模糊搜索
May 10 jQuery
jquery实现掷骰子小游戏
Oct 24 jQuery
jQuery实现全选按钮
Jan 01 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 缩略图实现函数代码
2011/06/23 PHP
php+html5+ajax实现上传图片的方法
2016/05/14 PHP
PHP上传图片类显示缩略图功能
2016/06/30 PHP
浅析PHP数据导出知识点
2018/02/17 PHP
PhpStorm配置Xdebug调试的方法步骤
2019/02/02 PHP
Javascript 学习书 推荐
2009/06/13 Javascript
vue省市区三联动下拉选择组件的实现
2017/04/28 Javascript
原生JS+Canvas实现五子棋游戏实例
2017/06/19 Javascript
Javascript实现跨域后台设置拦截的方法详解
2017/08/04 Javascript
vue3.0 CLI - 3.2 路由的初级使用教程
2018/09/20 Javascript
iview同时验证多个表单问题总结
2018/09/29 Javascript
vue2.0中set添加属性后视图不能更新的解决办法
2019/02/22 Javascript
解决vue单页面多个组件嵌套监听浏览器窗口变化问题
2020/07/30 Javascript
vue根据条件不同显示不同按钮的操作
2020/08/04 Javascript
vue项目在线上服务器访问失败原因分析
2020/08/14 Javascript
vue+Element-ui实现分页效果
2020/11/15 Javascript
python中__slots__用法实例
2015/06/04 Python
python的dataframe和matrix的互换方法
2018/04/11 Python
谈谈Python中的while循环语句
2019/03/10 Python
django序列化serializers过程解析
2019/12/14 Python
Python如何读取、写入JSON数据
2020/07/28 Python
python 用struct模块解决黏包问题
2020/11/07 Python
美国畅销的跑步机品牌:ProForm
2017/02/06 全球购物
英国健身仓库:Bodybuilding Warehouse
2019/03/06 全球购物
英国川宁茶官方网站:Twinings茶
2019/05/21 全球购物
英国Flybe航空官网:欧洲最大的独立支线廉价航空公司
2019/07/15 全球购物
物业经理求职自我评价
2013/09/22 职场文书
大学团支书的自我评价分享
2013/12/14 职场文书
如何写一封打动人心的求职信
2014/02/17 职场文书
小学生元旦感言
2014/02/26 职场文书
三八妇女节活动主持词
2014/03/17 职场文书
2014年公务员退休工资改革方案
2014/10/01 职场文书
团代会闭幕词
2015/01/28 职场文书
工商局个人工作总结
2015/03/03 职场文书
党风廉洁教育心得体会
2016/01/20 职场文书
幼儿园教学反思范文
2016/03/02 职场文书