JS中如何制作一个竖向可折叠的二级菜单功能
Admin 2022-07-01 群英技术资讯 923 次浏览
这篇文章主要讲解了“JS中如何制作一个竖向可折叠的二级菜单功能”,文中的讲解内容简单、清晰、详细,对大家学习或是工作可能会有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。本文实例为大家分享了JavaScript实现二级菜单效果的具体代码,供大家参考,具体内容如下
这次实现的效果图如下:

这个二级菜单实现的效果是:
当点击某一个框时,会将已经打开的框的内容收回,再展开现在点击的框的内容。
那要如何实现这个效果呢?
我们可以step by step
1、首先我们要将整个框架显示出来,即所有框展开的样子,因为其显示/不显示是拿overflow:hidden做的。
但是要注意不要所有的框都拿一种类型的盒子做,因为那样不方便写js代码,毕竟我们之后的操作是点击绿色的框=>使得收起或展开白色的框,所以我们需要为每一个天数+对应课程的框放在一个div父盒子下。然后为其初始化:设置高度等于span的高度,设置overflow:hidden,如下图,可以结合下面代码

2、然后开始写js部分:确保点击某一框时,它会由闭合变为展开。我们的框是span,如果想要span的父盒子div中的内容全部显示,我们首先需要通过document.getElementsByTagName("span")获取所有的span,然后利用for循环在每一个span的onclick响应函数中通过parentNode获取其对应的父盒子,使其父盒子的高度变为其scrollHeight的值
3、然后我们需要在点击span使某盒子展开的时候,将已经展开的盒子收起。这时我们就需要一个变量now来记录上次被点击的盒子,令其初值为null,若now不等于当前点击的span,则获取now的父盒子,令其高度变为span的高度,然后令当前点击的span展开(第二点已经讲了怎么展开);若now等于当前点击的span,获取其父盒子的高度,如果等于span的高度,则令其高度变为scrollHeight的值,否则令其变为span的高度
4、设置定时器,在准备将父盒子高度增加或减少的时候调用,当父盒子高度达到span的高度或达到scrollHeight,就关闭定时器(可以设置两个定时器)
代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<style>
* {
margin: 0;
padding: 0;
}
.container {
width: 300px;
height: 700px;
margin: 100px auto;
}
.container div {
height: 43px;
overflow: hidden;
}
.container div span {
width: 150px;
height: 40px;
line-height: 40px;
border-radius: 15px;
display: block;
text-align: center;
background-color: rgba(104, 250, 201, 0.849);
cursor: pointer;
}
a {
width: 150px;
height: 40px;
line-height: 40px;
text-decoration: none;
display: block;
text-align: center;
}
</style>
</head>
<body>
<div class="container">
<div id="">
<span id="one">周一</span>
<a href="">可视化</a>
<a href="">可视化</a>
</div>
<div id="">
<span id="two">周二</span>
<a href="">算法设计</a>
<a href="">图形学</a>
<a href="">计组课设</a>
<a href="">操作系统</a>
</div>
<div id="">
<span id="three">周四</span>
<a href="">形势与政策</a>
<a href="">操作系统</a>
</div>
<div id="">
<span id="four">周五</span>
<a href="">算法设计</a>
</div>
</div>
<script>
let menu = document.getElementsByTagName("span");
let now = null;
for (let i = 0; i < menu.length; i++) {
menu[i].onclick = function () {
let par = menu[i].parentNode;
if (now === i) {
if (par.style.height === "43px") {
open(par);
}
else {
close(par);
}
}
else {
if (now !== null) {
close(menu[now].parentNode);
}
open(par);
now = i;
}
}
}
function open(par) {
let tem = setInterval(() => {
let num = par.offsetHeight;
if (num >= par.scrollHeight) {
clearInterval(tem);
}
par.style.height = num + 1 + "px";
}, 7);
}
function close(par) {
let tem = setInterval(() => {
let num = par.offsetHeight;
if (num <= 43) {
clearInterval(tem);
return;
}
par.style.height = num - 1 + "px";
}, 7);
}
</script>
</body>
</html>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要介绍了javascript获取指针的位置的方法,通过代码介绍了如何调用上面扩展函数 getMP() 捕获当前鼠标指针在文档中的位置,需要的朋友可以参考下
这篇文章主要介绍了vue-resource 拦截器interceptors使用详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
目录前言动画的本质动画的实现动画的推导小结前言到目前为止我们的 fabric.js 雏形已经有了,麻雀虽小五脏俱全,我们不仅能够在画布上自由的添加物体,同时还实现了点选和框选,并且能够对它们做一些变换,不过只有变换这个操作还不够灵活,要是能够让物体动起来就好了,于是就引入了这个章节的主题:动画,以及动画最核心的一个问题
本文介绍的JS解构的内容,什么是JS解构呢?ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构,简单的了解完JS解构,接下来我们看数组解构、对象的解构赋值、字符串解构、解构赋值的应用等等。感兴趣的朋友就继续往下看吧。
今天来给大家简单的聊一聊Rx响应式编程,对于Rx响应式编程的学习,Observable的内容是需要掌握了解的,因此下面小编就给大家来介绍一下Observable,有这方面学习需要的朋友可以参考。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008