首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在单击任何其他父菜单的子菜单或相同的子菜单时关闭多个子菜单

在前端开发中,可以通过以下步骤来实现在单击任何其他父菜单的子菜单或相同的子菜单时关闭多个子菜单:

  1. 首先,为每个父菜单添加一个点击事件监听器,以便在点击时触发相应的操作。
  2. 当点击某个父菜单时,可以使用DOM操作方法(如querySelector、classList等)获取所有子菜单的元素,可以根据CSS选择器进行选择,或者通过遍历父菜单的子元素来获取子菜单。
  3. 对于获取到的子菜单元素,可以使用classList方法来添加或删除指定的CSS类名,用于控制子菜单的显示或隐藏状态。
  4. 在点击事件监听器中,可以先判断当前点击的父菜单是否已经处于展开状态,如果是,则将其关闭。可以通过检查父菜单元素的classList中是否包含表示展开状态的CSS类名来进行判断。
  5. 在关闭当前父菜单之后,可以使用循环或迭代的方式遍历所有其他父菜单,将它们的子菜单隐藏起来。可以通过遍历父菜单元素的兄弟节点,检查它们的子菜单元素是否处于展开状态,并进行关闭操作。
  6. 另外,为了提高用户体验,可以在操作过程中添加一些动画效果,使菜单的展开和关闭更加平滑。

以下是一些示例代码,用于演示如何实现上述功能:

HTML部分:

代码语言:txt
复制
<div class="parent-menu">
  <button class="parent-menu__button">父菜单</button>
  <ul class="child-menu">
    <li>子菜单1</li>
    <li>子菜单2</li>
    <li>子菜单3</li>
  </ul>
</div>
<!-- 其他类似结构的父菜单和子菜单 -->

CSS部分:

代码语言:txt
复制
.child-menu {
  display: none;
}

JavaScript部分:

代码语言:txt
复制
// 获取所有父菜单按钮元素
const parentMenuButtons = document.querySelectorAll('.parent-menu__button');

// 给每个父菜单按钮添加点击事件监听器
parentMenuButtons.forEach(button => {
  button.addEventListener('click', () => {
    const currentParentMenu = button.parentNode;
    const currentChildMenu = currentParentMenu.querySelector('.child-menu');

    if (currentParentMenu.classList.contains('open')) {
      // 关闭当前父菜单
      currentParentMenu.classList.remove('open');
      currentChildMenu.style.display = 'none';
    } else {
      // 关闭其他父菜单并展开当前父菜单
      parentMenuButtons.forEach(otherButton => {
        const otherParentMenu = otherButton.parentNode;
        if (otherParentMenu !== currentParentMenu) {
          otherParentMenu.classList.remove('open');
          otherParentMenu.querySelector('.child-menu').style.display = 'none';
        }
      });
      currentParentMenu.classList.add('open');
      currentChildMenu.style.display = 'block';
    }
  });
});

以上代码中,我们通过给父菜单按钮添加一个CSS类名来表示它的展开状态。当点击父菜单按钮时,通过判断该按钮所在的父菜单元素是否含有该类名来判断它是否已经展开,从而实现展开和关闭的效果。

请注意,上述示例代码只是一种实现方式,具体实现可能因项目需求和技术栈的不同而有所差异。在实际开发中,可以根据具体情况进行调整和优化。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • C#学习笔记—— 常用控件说明及其属性、事件

    1、 窗体 的属性 1、常用属性 (1)Name属性:用来获取或设置窗体的名称,在应用程序中可通过Name属性来引用窗体。 (2) WindowState属性: 用来获取或设置窗体的窗口状态。 取值有三种: Normal (窗体正常显示)、 Minimized(窗体以最小化形式显示)和 Maximized(窗体以最大化形式显示)。 (3)StartPosition属性:用来获取或设置运行时窗体的起始位置。其取值及含义如表9-1 所示。默认的起始位置是WindowsDefaultLocation。 (4)Text属性:该属性是一个字符串属性,用来设置或返回在窗口标题栏中显示的文字。 (5)Width属性:用来获取或设置窗体的宽度。 (6)Height属性:用来获取或设置窗体的高度。 (7)Left属性:用来获取或设置窗体的左边缘的x坐标(以像素为单位)。 (8)Top属性:用来获取或设置窗体的上边缘的y坐标(以像素为单位)。 (9)ControlBox属性:用来获取或设置一个值,该值指示在该窗体的标题栏中是否显示控制框。值为true时将显示控制框,值为false时不显示控制框。 (10)MaximizeBox属性:用来获取或设置一个值,该值指示是否在窗体的标题栏中显示最大化按钮。值为 true时显示最大化按钮,值为false时不显示最大化按钮。 (11)MinimizeBox 属性:用来获取或设置一个值,该值指示是否在窗体的标题栏中显示最小化按钮。值为 true时显示最小化按钮,值为false时不显示最小化按钮。 (12)AcceptButton 属性:该属性用来获取或设置一个值,该值是一个按钮的名称,当按 Enter 键时就相当于单击了窗体上的该按钮。 (13)CancelButton 属性:该属性用来获取或设置一个值,该值是一个按钮的名称,当按 Esc 键时就相当于单击了窗体上的该按钮。 (14)Modal 属性:该属性用来设置窗体是否为有模式显示窗体。如果有模式地显示该窗体,该属性值为true;否则为 false。当有模式地显示窗体时,只能对模式窗体上的对象进行输入。必须隐藏或关闭模式窗体(通常是响应某个用户操作),然后才能对另一窗体进行输入。有模式显示的窗体通常用做应用程序中的对话框。 (15)ActiveControl属性:用来获取或设置容器控件中的活动控件。窗体也是一种容器控件。 (16)ActiveMdiChild属性:用来获取多文档界面(MDI)的当前活动子窗口。 (17)AutoScroll 属性:用来获取或设置一个值,该值指示窗体是否实现自动滚动。如果此属性值设置为true,则当任何控件位于窗体工作区之外时,会在该窗体上显示滚动条。另外当自动滚动打开时,窗体的工作区自动滚动,以使具有输入焦点的控件可见。 (18)BackColor属性:用来获取或设置窗体的背景色。 (19)BackgroundImage属性:用来获取或设置窗体的背景图像。 (20)Enabled 属性:用来获取或设置一个值,该值指示控件是否可以对用户交互作出响应。如果控件可以对用户交互作出响应,则为 true;否则为false。默认值为true。 (21)Font属性:用来获取或设置控件显示的文本的字体。 (22)ForeColor属性:用来获取或设置控件的前景色。 (23)IsMdiChild属性:获取一个值,该值指示该窗体是否为多文档界面(MDI)子窗体。值为 true时,是子窗体,值为false时,不是子窗体。 (24)IsMdiContainer 属性:获取或设置一个值,该值指示窗体是否为多文档界面(MDI)中的子窗体的容器。值为true时,是子窗体的容器,值为false时,不是子窗体的容器。 (25)KeyPreview属性:用来获取或设置一个值,该值指示在将按键事件传递到具有焦点的控件前,窗体是否将接收该事件。值为true时,窗体将接收按键事件,值为false时,窗体不接收按键事件。 (26)MdiChildren属性:数组属性。数组中的每个元素表示以此窗体作为父级的多文档界面(MDI)子窗体。 (27)MdiParent属性:用来获取或设置此窗体的当前多文档界面(MDI)父窗体。 (28)ShowInTaskbar属性:用来获取或设置一个值,该值指示是否在Windows任务栏中显示窗体。 (29)Visible属性:用于获取或设置一个值,该值指示是否显示该窗体或控件。值为true 时显示窗体或控件,为 false时不显示。 (30)Capture属性:如果该属性值为true,则鼠标就会被限定只由此控件响应,不管鼠标是否在此控件的范围内。 2、常用的方法 下面介绍一些窗体的最常用方法。 (1)Show方法:该方法的作用是让窗体显示出来,其调用格式为: 窗体名.

    02

    Windows10中的键盘快捷方式

    Windows 徽标键 + Shift + C打开超级按钮菜单Windows 徽标键 + D显示和隐藏桌面Windows 徽标键 + Alt + D显示和隐藏桌面上的日期和时间Windows 徽标键 + E打开文件资源管理器Windows 徽标键 + F打开反馈中心并获取屏幕截图Windows 徽标键 + G打开游戏栏(当游戏处于打开状态时)Windows 徽标键 + H开始听写Windows 徽标键  + I打开“设置”Windows 徽标键 + J 请将焦点设置到可用的 Windows 提示。 当出现 Windows 提示时,请将焦点移到提示上。 再次按下键盘快捷方式,将焦点放在屏幕上 Windows 提示所固定的元素上。Windows 徽标键 + K打开“连接”快速操作Windows 徽标键 + L锁定你的电脑或切换帐户Windows 徽标键 + M最小化所有窗口Windows 徽标键 + O锁定设备方向Windows 徽标键 + P选择演示显示模式Windows 徽标键 + R打开“运行”对话框Windows 徽标键 + S打开“搜索”Windows 徽标键 + T循环浏览任务栏上的应用Windows 徽标键 + U打开“轻松使用设置中心”Windows 徽标键 + V循环浏览通知Windows 徽标键 + Shift + V以相反顺序循环浏览通知Windows 徽标键 + X打开“快速链接”菜单Windows 徽标键  + Y在 Windows Mixed Reality 与桌面之间切换输入Windows 徽标键 + Z以全屏模式显示应用中可用的命令Windows 徽标键 + 句点 (.) 或分号 (;)打开表情符号面板Windows 徽标键 + 逗号 (,)临时速览桌面Windows 徽标键 + Pause 键显示“系统属性”对话框Windows 徽标键 + Ctrl + F搜索电脑(如果已连接到网络)Windows 徽标键 + Shift + M还原桌面上的最小化窗口Windows 徽标键 + 数字打开桌面,然后启动固定到任务栏的应用(位于数字所指明的位置)。如果应用已处于运行状态,则切换至该应用。Windows 徽标键 + Shift + 数字打开桌面,然后启动固定到任务栏的应用新实例(位于数字所指明的位置)Windows 徽标键 + Ctrl + 数字打开桌面,然后切换至固定到任务栏的应用的最后活动窗口(位于数字所指明的位置)Windows 徽标键 + Alt + 数字打开桌面,然后打开固定到任务栏的应用的“跳转列表”(位于数字所指明的位置)Windows 徽标键 + Ctrl + Shift + 数字打开桌面,然后以管理员身份打开位于任务栏上指定位置的应用新实例Windows 徽标键 + Tab打开任务视图Windows 徽标键 向上键最大化窗口Windows 徽标键 向下键删除屏幕上的当前应用并最小化桌面窗口Windows 徽标键 + 向左键最大化屏幕左侧的应用或桌面窗口Windows 徽标键 + 向右键最大化屏幕右侧的应用或桌面窗口Windows 徽标键 + Home最小化活动桌面窗口之外的所有窗口(在第二个笔划时还原所有窗口)Windows 徽标键 + Shift + 向上键将桌面窗口拉伸至屏幕顶部和底部Windows 徽标键 + Shift + 向下键在垂直方向上还原/最小化活动桌面窗口,而宽度保持不变Windows 徽标键 Shift + 向左键或向右键将桌面上的应用或窗口从一台显示器移动至另一台显示器Windows 徽标键+ 空格键切换输入语言和键盘布局Windows 徽标键+ Ctrl + 空格键对之前选择的输入所做的更改Windows 徽标键+ Ctrl + Enter打开讲述人Windows 徽标键+ 加号 (+)打开放大镜Windows 徽标键+ 正斜杠 (/)开始输入法复原流程Windows 徽标键  + Ctrl + V打开肩式分接设备 命令提示符键盘快捷方式

    02
    领券