javascript - 默认打开手风琴
问题描述
两天前我正在学习 html/css 并学习了手风琴菜单。但我想反过来做同样的事情。换句话说,菜单会在启动时打开,当我点击标题时,它们会折叠起来。不幸的是,我永远无法做到这一点。有人有想法吗?
var acc = document.getElementsByClassName("accordion");
var i;
for (i = 0; i < acc.length; i++) {
acc[i].addEventListener("click", function() {
this.classList.toggle("active");
var panel = this.nextElementSibling;
if (panel.style.maxHeight) {
panel.style.maxHeight = null
} else {
panel.style.maxHeight = panel.scrollHeight + "px";
}
});
}
.accordion {
background-color: #FFFFFF;
cursor: pointer;
padding: 18px;
width: 100%;
border: none;
text-align: left;
font-size: 15px;
}
.accordion:after {
content: "\002B";
/* plus sign */
font-weight: bold;
float: right;
margin-left: 5px;
}
.active:after {
content: "\2212";
}
/* minus sign */
.panel {
padding: 0 18px;
max-height: 0;
overflow: hidden;
transition: max-height 0.2s ease-out;
}
<table width="750">
<td style="width: 100%;">
<button class="accordion">Header 1</button>
<div class="panel">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor</p>
</div>
<button class="accordion">Header 2</button>
<div class="panel">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor</p>
</div>
<button class="accordion">Header 3</button>
<div class="panel">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor</p>
</div>
</td>
</table>
解决方案
简单的手动添加active
到面板accordion button
style="max-height: 50px;"
var acc = document.getElementsByClassName("accordion");
var i;
for (i = 0; i < acc.length; i++) {
acc[i].addEventListener("click", function() {
this.classList.toggle("active");
var panel = this.nextElementSibling;
if (panel.style.maxHeight) {
panel.style.maxHeight = null
} else {
panel.style.maxHeight = panel.scrollHeight + "px";
}
});
}
.accordion {
background-color: #FFFFFF;
cursor: pointer;
padding: 18px;
width: 100%;
border: none;
text-align: left;
font-size: 15px;
}
.accordion:after {
content: "\002B";
/* plus sign */
font-weight: bold;
float: right;
margin-left: 5px;
}
.active:after {
content: "\2212";
}
/* minus sign */
.panel {
padding: 0 18px;
max-height: 0;
overflow: hidden;
transition: max-height 0.2s ease-out;
}
<table width="750">
<td style="width: 100%;">
<button class="accordion active">Header 1</button>
<div class="panel" style="max-height: 50px;">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor</p>
</div>
<button class="accordion active">Header 2</button>
<div class="panel" style="max-height: 50px;">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor</p>
</div>
<button class="accordion active">Header 3</button>
<div class="panel" style="max-height: 50px;">
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor</p>
</div>
</td>
</table>
推荐阅读
- shell - 我输入了一个 shellscript 程序来生成一个数字表。我正在使用onworks(在线操作系统平台)
- android - Android 中的 Firebase 通知 (Kotlin)
- centos - 构建 HPL 的问题
- neural-network - 为什么 GAN 需要潜在空间噪声作为输入?
- python - 在TensorFlow中同时沿多个轴的Argmax
- reactjs - 类型错误:document.getElementById(...) 为空;使用 axios 做出反应
- deep-learning - Vnet 深度学习 3D 体积图像分割。如何处理大尺寸和不同尺寸的图像?
- database - 使用golang在postgres中从csv批量插入而不使用for循环
- asp.net - 捕获回发 URL 调用
- python - 将 dask DataFrame 作为参数传递给任务