我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript实现伸缩二级菜单

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript实现伸缩二级菜单

JavaScript实现伸缩二级菜单的具体代码,供大家参考,具体内容如下

伸缩二级菜单:

案例说明:效果图如下,一次只能打开一个,打开后,+ 号变 - 。

HTML 代码


<!--伸拉列表-->
<style>
 
    li {
        
        list-style: none;
    }
 
    li span {
        
        background: url(add.png) no-repeat left center;
        padding-left: 20px;
    }
 
    
    li ul{
        height: 0;
        
        overflow: hidden;
        
        transition: all 0.5s;
    }
    
    .open{
        background-image: url(minus.png);
    }
    .open+ul{
        height: 70px;
    }
 
 
</style>
 
 
<ul class="tree">
    <li><span class="open">考勤管理</span>
        <ul>
            <li>日常考勤</li>
            <li>请假申请</li>
            <li>加班出差</li>
        </ul>
    </li>
    <li><span>信息中心</span>
        <ul>
            <li>日常考勤</li>
            <li>请假申请</li>
            <li>加班出差</li>
        </ul>
    </li>
    <li><span>协同办公</span>
        <ul>
            <li>日常考勤</li>
            <li>请假申请</li>
            <li>加班出差</li>
        </ul>
    </li>
</ul>
 
<script class="lazy" data-src="mJS.js"></script>

JavaScript 代码


// 伸拉列表
 
// 实现思路:
 
var spans = document.querySelectorAll(".tree span");
 
for (var i = 0; i < spans.length; i++) {
    spans[i].onclick = function () {
        // console.log(this);
        // 查找要修改的元素 span 自己
        // 修改,删除或添加 class -> open
        // 判断自己身上是不是有 open,如果有,删除!
        // this ->指向触发事件的元素本身
        if (this.className == "open") {
            // 如果有,删除!
            this.className = "";
        } else {
            // 如果没有,则添加 ,删除其他已经打开的!
            //找到打开(open属性的li)
            var openSpan = document.querySelector(".tree .open")
            if (openSpan !== null) {
                // 如果集合不为空,删除他们的 open 属性
                openSpan.className = "";
            }
            // 给自己设置 open 属性
            this.className = "open";
        }
 
 
    }
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript实现伸缩二级菜单

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android实现伸缩弹力分布菜单效果的示例

这两天无意间看到一园友的博文实现Path2.0中绚丽的的旋转菜单,感觉效果不错,但是发现作者没有处理线程安全的问题,所以在这里我修正了下,并且改善下部分功能。今天发布这篇文章的目的是希望能在Android用户体验上提出一些相关的解决方案,方
2022-06-06

Android实现横向二级菜单

本文实例为大家分享了Android二级横向菜单的实现过程.效果如上图: 这种横向的二级菜单在很多的app都有所应用.效果看起来还是非常的美观的.也算是项目需要,自己也就学了一下这个效果,首先说一下逻辑.实现的方式其实并不是很难..只
2022-06-06

java二级菜单怎么实现

实现Java二级菜单可以通过使用多层嵌套的菜单结构来实现。以下是一个简单的示例代码:import java.util.Scanner;public class Main {public static void main(String[]
java二级菜单怎么实现
2024-03-13

vue3element-plus二次封装组件系列之伸缩菜单制作

这篇文章主要介绍了vue3element-plus二次封装组件系列之伸缩菜单制作,是基于vue3viteelement-plus搭建的,值的注意的时候,里面的图标组件是经过处理的,结合实例代码介绍的非常详细,需要的朋友可以参考下
2023-01-16

纯css如何实现二级菜单

这篇“纯css如何实现二级菜单”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“纯css如何实现二级菜单”文章吧。HTML结构设
2023-07-05

WordPress 3.0+菜单功能支持二级和N级菜单实现步骤

自带的导航菜单功能是 WordPress 3.0+ 中唯一执得让人眼睛一亮的功能了,在新做主题的过程中再一次让我眼睛亮了一亮,发现这个 WordPress 的导航菜单居然还支持二级和N级菜单。 当然要实现下拉的二级菜单功能,还是需要 jqu
2022-06-12

怎么使用vue3 element-plus二次封装组件制作伸缩菜单

本篇内容主要讲解“怎么使用vue3 element-plus二次封装组件制作伸缩菜单”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用vue3 element-plus二次封装组件制作伸缩菜
2023-07-05

css如何实现动态二级菜单

这篇文章将为大家详细讲解有关css如何实现动态二级菜单,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。动态实现简单的二级菜单当鼠标放到一级标签上时,鼠标会变成小手的形状 展示二级菜单,源码如下,复制即可直接
2023-06-08

php实现二级联动菜单的方法

小编给大家分享一下php实现二级联动菜单的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!php实现二级联动菜单的方法:首先创建好HTML文件和PHP文件;然后
2023-06-14

编程热搜

目录