javascript - 手风琴只打开一次然后出现故障
问题描述
谁能确定为什么我的手风琴没有无限点击和关闭,点击几下后出现故障?
当我在它自己的 HTML/CSS/JS 文件中尝试此操作时,没有其他任何操作,它可以完美运行。我不知道什么可能会阻止这项工作。
我一直在努力解决这个问题,这让我很生气。我无法确定问题出在哪里,欢迎提出任何建议!
const acc = document.getElementsByClassName('accordion');
let i;
for (i = 0; i < acc.length; i++) {
acc[i].addEventListener('click', function () {
this.classList.toggle('active');
let panel = this.nextElementSibling;
if (panel.style.maxHeight) {
panel.style.maxHeight = 0;
} else {
panel.style.maxHeight = panel.scrollHeight + 'px';
}
});
}
@media only screen and (max-width: 767px) {
.table-accordion {
display: block !important;
}
.accordion {
color: rgb(35, 35, 35);
cursor: pointer;
padding: 10px 3px;
width: 100%;
border: none;
border-bottom: rgb(186, 186, 186) 1px solid;
outline: none;
font-size: 12px;
text-align: left;
transition: 0.4s;
flex-wrap: wrap;
background: none;
font-family: inherit;
}
.accordion:focus {
border: none;
}
.active,
.accordion:hover {
color: black;
}
.accordion:after {
content: '\2715';
transform: rotate(45deg);
color: black;
font-weight: bold;
float: right;
margin-left: 5px;
transition: 0.3s ease-in;
}
.active:after {
content: '\2715';
transform: rotate(90deg);
transition: 0.3s ease-in;
}
.panel {
margin: 0px;
line-height: 2;
padding: 0px 10px;
color: #fff;
font-family: inherit;
font-size: 12px;
font-weight: 400;
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease;
}
.panel a:hover {
color: rgb(52, 52, 52);
text-decoration: underline;
}
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="table-accordion">
<button class="accordion">Shop and Learn</button>
<div class="panel">
<ul>
<li><a href="#">Mac</a></li>
<li><a href="#">iPad</a></li>
<li><a href="#">iPhone</a></li>
<li><a href="#">Watch</a></li>
<li><a href="#">TV</a></li>
<li><a href="#">Music</a></li>
<li><a href="#">AirPods</a></li>
<li><a href="#">HomePod</a></li>
<li><a href="#">iPod Touch</a></li>
<li><a href="#">Accessories</a></li>
<li><a href="#">Gift Cards</a></li>
</ul>
</div>
<button class="accordion">Services</button>
<div class="panel">
<ul>
<li><a href="#">Apple Music</a></li>
<li><a href="#">Apple News+</a></li>
<li><a href="#">Apple TV+</a></li>
<li><a href="#">Apple Arcade</a></li>
<li><a href="#">Apple Books</a></li>
<li><a href="#">iCloud</a></li>
</ul>
</div>
<button class="accordion">Account</button>
<div class="panel">
<ul>
<li><a href="#">Manage Your Apple ID</a></li>
<li><a href="#">Apple Store Account</a></li>
<li><a href="#">iCloud.com</a></li>
</ul>
</div>
<button class="accordion">Apple Store</button>
<div class="panel">
<ul>
<li><a href="#">Find a Store</a></li>
<li><a href="#">Shop Online</a></li>
<li><a href="#">Genius Bar</a></li>
<li><a href="#">Today at Apple</a></li>
<li><a href="#">Apple Summer Camp</a></li>
<li><a href="#">Apple Store App</a></li>
<li><a href="#">Refurbished and Clearance</a></li>
<li><a href="#">Financing</a></li>
<li><a href="#">Apple Trade In</a></li>
<li><a href="#">Order Status</a></li>
<li><a href="#">Shopping Help</a></li>
</ul>
</div>
<button class="accordion">For Business</button>
<div class="panel">
<ul>
<li><a href="#">Apple and Business</a></li>
<li><a href="#">Shop for Business</a></li>
</ul>
</div>
<button class="accordion">For Education</button>
<div class="panel">
<ul>
<li><a href="#">Apple and Education</a></li>
<li><a href="#">Shop for University</a></li>
</ul>
</div>
<button class="accordion">For Healthcare</button>
<div class="panel">
<ul>
<li><a href="#">Apple in Healthcare</a></li>
<li><a href="#">Health on Apple Watch</a></li>
</ul>
</div>
<button class="accordion">Apple Values</button>
<div class="panel">
<ul>
<li><a href="#">Accessibility</a></li>
<li><a href="#">Environment</a></li>
<li><a href="#">Privacy</a></li>
<li><a href="#">Supplier Responsibility</a></li>
</ul>
</div>
<button class="accordion">About Apple</button>
<div class="panel">
<ul>
<li><a href="#">Newsroom</a></li>
<li><a href="#">Apple Leadership</a></li>
<li><a href="#">Job Opportunities</a></li>
<li><a href="#">Warranty</a></li>
<li><a href="#">Investors</a></li>
<li><a href="#">Events</a></li>
<li><a href="#">European Job Creation</a></li>
<li><a href="#">Contact Apple</a></li>
</ul>
</div>
</div>
解决方案
发生这种情况是因为最初style.maxHeight
的值为 null ,所以当我们if
第一次在里面检查它时,它会返回false
,但是当你将它设置为“0”时,它的实际字符串0px
不是int
,这会导致在下一次检查中条件为真。
只需添加另一个条件panel.style.maxHeight!="0px"
,它就会按预期工作。
const acc = document.getElementsByClassName('accordion');
let i;
for (i = 0; i < acc.length; i++) {
acc[i].addEventListener('click', function () {
this.classList.toggle('active');
let panel = this.nextElementSibling;
// Change
if (panel.style.maxHeight && panel.style.maxHeight!="0px") {
// End of change
panel.style.maxHeight = 0;
} else {
panel.style.maxHeight = panel.scrollHeight + 'px';
}
});
}
@media only screen and (max-width: 767px) {
.table-accordion {
display: block !important;
}
.accordion {
color: rgb(35, 35, 35);
cursor: pointer;
padding: 10px 3px;
width: 100%;
border: none;
border-bottom: rgb(186, 186, 186) 1px solid;
outline: none;
font-size: 12px;
text-align: left;
transition: 0.4s;
flex-wrap: wrap;
background: none;
font-family: inherit;
}
.accordion:focus {
border: none;
}
.active,
.accordion:hover {
color: black;
}
.accordion:after {
content: '\2715';
transform: rotate(45deg);
color: black;
font-weight: bold;
float: right;
margin-left: 5px;
transition: 0.3s ease-in;
}
.active:after {
content: '\2715';
transform: rotate(90deg);
transition: 0.3s ease-in;
}
.panel {
margin: 0px;
line-height: 2;
padding: 0px 10px;
color: #fff;
font-family: inherit;
font-size: 12px;
font-weight: 400;
max-height: 0;
overflow: hidden;
transition: max-height 0.4s ease;
}
.panel a:hover {
color: rgb(52, 52, 52);
text-decoration: underline;
}
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="table-accordion">
<button class="accordion">Shop and Learn</button>
<div class="panel">
<ul>
<li><a href="#">Mac</a></li>
<li><a href="#">iPad</a></li>
<li><a href="#">iPhone</a></li>
<li><a href="#">Watch</a></li>
<li><a href="#">TV</a></li>
<li><a href="#">Music</a></li>
<li><a href="#">AirPods</a></li>
<li><a href="#">HomePod</a></li>
<li><a href="#">iPod Touch</a></li>
<li><a href="#">Accessories</a></li>
<li><a href="#">Gift Cards</a></li>
</ul>
</div>
<button class="accordion">Services</button>
<div class="panel">
<ul>
<li><a href="#">Apple Music</a></li>
<li><a href="#">Apple News+</a></li>
<li><a href="#">Apple TV+</a></li>
<li><a href="#">Apple Arcade</a></li>
<li><a href="#">Apple Books</a></li>
<li><a href="#">iCloud</a></li>
</ul>
</div>
<button class="accordion">Account</button>
<div class="panel">
<ul>
<li><a href="#">Manage Your Apple ID</a></li>
<li><a href="#">Apple Store Account</a></li>
<li><a href="#">iCloud.com</a></li>
</ul>
</div>
<button class="accordion">Apple Store</button>
<div class="panel">
<ul>
<li><a href="#">Find a Store</a></li>
<li><a href="#">Shop Online</a></li>
<li><a href="#">Genius Bar</a></li>
<li><a href="#">Today at Apple</a></li>
<li><a href="#">Apple Summer Camp</a></li>
<li><a href="#">Apple Store App</a></li>
<li><a href="#">Refurbished and Clearance</a></li>
<li><a href="#">Financing</a></li>
<li><a href="#">Apple Trade In</a></li>
<li><a href="#">Order Status</a></li>
<li><a href="#">Shopping Help</a></li>
</ul>
</div>
<button class="accordion">For Business</button>
<div class="panel">
<ul>
<li><a href="#">Apple and Business</a></li>
<li><a href="#">Shop for Business</a></li>
</ul>
</div>
<button class="accordion">For Education</button>
<div class="panel">
<ul>
<li><a href="#">Apple and Education</a></li>
<li><a href="#">Shop for University</a></li>
</ul>
</div>
<button class="accordion">For Healthcare</button>
<div class="panel">
<ul>
<li><a href="#">Apple in Healthcare</a></li>
<li><a href="#">Health on Apple Watch</a></li>
</ul>
</div>
<button class="accordion">Apple Values</button>
<div class="panel">
<ul>
<li><a href="#">Accessibility</a></li>
<li><a href="#">Environment</a></li>
<li><a href="#">Privacy</a></li>
<li><a href="#">Supplier Responsibility</a></li>
</ul>
</div>
<button class="accordion">About Apple</button>
<div class="panel">
<ul>
<li><a href="#">Newsroom</a></li>
<li><a href="#">Apple Leadership</a></li>
<li><a href="#">Job Opportunities</a></li>
<li><a href="#">Warranty</a></li>
<li><a href="#">Investors</a></li>
<li><a href="#">Events</a></li>
<li><a href="#">European Job Creation</a></li>
<li><a href="#">Contact Apple</a></li>
</ul>
</div>
</div>
推荐阅读
- java - How to fix JaCoCo reportDir is deprecated
- abp - 子实体未从主存储库 ABP 框架更新
- javascript - 页面加载时待办事项状态的本地存储问题
- javascript - 如何在角度中使用材质 UI 使用元素参考?
- typescript - 未处理的拒绝(SessionError):用户不是频道成员
- asp.net-core - 在使用 listbox.SelectedItem 时,我收到 getEnumerator 错误,当我使用 listbox.item 时,我得到 listbox .net 中存在的所有项目
- html - Pandoc:将标题之间的内容放在一个
- android - 从模拟实例调用 fun 抛出 NullPointerExcception
- java - Spring Cloud Router Sink 3.0.2 需要 Kafka Avro (De)Serializer
- html - HTML 中输入字段的预验证