- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下代码:
function toggle(index, mode) {
var elem = document.getElementById("accordion-content" + index);
var moreTime = document.getElementById("more-time-text" + index);
var icon = document.getElementById("arr-icon" + index);
var hoursTitle = document.getElementById("hours-title" + index);
var clsName;
var hoursTitleTxt = "";
var buttonText = ""; /* If this accordion is close (need to close the other div that open, even if none is open) */
if (elem.className == "accordion-content") { /* close all divs and change their icons to arrow down (though only one is open every moment) */
collapseAll("accordion-content-clicked", "accordion-content"); /* change all div's text*/
changeTexts(); /* open this div */
clsName = "accordion-content-clicked"; /* change this div's icon */
icon.className = "accordion_up"; /* change text of button and title */
buttonText = "collapse";
hoursTitleTxt = "week's hours:"; /*change text and only then expand*/
hoursTitle.innerHTML = hoursTitleTxt;
moreTime.innerHTML = buttonText;
elem.addEventListener("transitionend", function afterEvent() {
elem.removeEventListener("transitionend", afterEvent)
/*elem.style.maxHeight = elem.offsetHeight + "px";*/
});
elem.className = clsName;
} /* this div is open */
else { /* close this div */
clsName = "accordion-content"; /* change the text of the button and title according the mode we're in */
if (mode == "Available") {
hoursTitleTxt = "week's hours:";
buttonText = "more hours";
} else if (mode == "NotAvailableToCall") {
hoursTitleTxt = "";
buttonText = "working hours:";
}
icon.className = "accordion_down"; /* collapse and only then change text */
elem.addEventListener("transitionend", function() {
hoursTitle.innerHTML = hoursTitleTxt;
});
elem.className = clsName;
moreTime.innerHTML = buttonText;
}
} /* collapse all divs and change the icon to arrow down */
function collapseAll(fromClass, toClass) {
$("." + fromClass).attr('class', toClass);
$("[id^='arr-icon']").attr('class', "accordion_down");
}
function changeTexts() {
var textList = $("[id^='more-time-text']");
for (var i = 0; i < textList.length; i++) {
var index = textList[i].getAttribute("index");
var parent = document.getElementById("more-time" + index);
var mode = parent.getAttribute("mode");
var title = document.getElementById("hours-title" + index);
var buttonText = "";
var titleText = "";
if (mode == "Available") {
buttonText = "expand";
titleText = "week's hours:";
} else if (mode == "NotAvailableToCall") {
buttonText = "week's hours";
titleText = "";
}
textList[i].innerHTML = buttonText;
title.innerHTML = titleText;
}
}
.accordion {
width: 94%;
margin: 0 5%;
}
.accordion-toggle {
-webkit-transition: background 1s linear;
-moz-transition: background 1s linear;
-ms-transition: background 1s linear;
-o-transition: background 1s linear;
transition: background 1s linear;
background: white;
border-radius: 3px;
display: block;
text-align: right;
text-decoration: none;
}
.accordion-content {
-webkit-transition: max-height 1s;
-moz-transition: max-height 1s;
-ms-transition: max-height 1s;
-o-transition: max-height 1s;
transition: max-height 1s;
background: white;
overflow: hidden;
max-height: 0;
}
.accordion-content-clicked
{
-webkit-transition: max-height 1s;
-moz-transition: max-height 1s;
-ms-transition: max-height 1s;
-o-transition: max-height 1s;
transition: max-height 1s;
background: white;
overflow: hidden;
max-height: 220px;
}
td.accordion_down {
background-image: url('');
width: 6px;
background-repeat: no-repeat;
background-size: contain;
display: table-cell;
vertical-align: middle;
background-position: center;
}
td.accordion_up {
background-image: url('');
width: 6px;
background-repeat: no-repeat;
background-size: contain;
display: table-cell;
vertical-align: middle;
background-position: center;
}
td.more-time-button {
display: table-cell;
vertical-align: middle;
padding-right: 4%;
padding: 0.25% 0;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="accordion2" class="accordion" index="2">
<div id="accordion-toggle" class="small-text-size accordion-toggle" index="2">
<div> <b><span id="hours-title2">working hours:</span></b> </div>
Tuesday
</div>
<div id="accordion-content2" class="accordion-content">
<div class="small-text-size workTimeTitle deleteRow"> <b><span id="Span1">week's hours</span></b> </div>
<div class="accordion-inner small-text-size">
Thursday
</div>
</div>
<div id="more-time2" class="very-small-text-size more-time" index="2" mode="Available" onclick="toggle(this.getAttribute('index'), this.getAttribute('mode'))">
<table>
<tr>
<td id="arr-icon2" class="accordion_down"> </td>
<td id="more-time-text2" class="more-time-button" index="2"> more hours </td>
</tr>
</table>
</div>
<div id="temp2"></div>
</div>
以及JsFiddle中的链接
展开后显示的文本是动态的:可以是 1 行或 6 行。使用css制作的动画,通过改变 最大高度:220px 或最大高度:0;
当我崩溃时,它需要时间才能真正崩溃,这是因为 max-height: 220px
并且只有 1 行。如果它是 6 行,它看起来会很好。
我尝试在 JS 中将 max-height 更改为 div 的实际高度(展开后),方法是:elem.style.maxHeight = elem.offsetHeight + "px";
但是它不起作用。
有什么建议为什么不起作用吗?
最佳答案
从 accordion-toggle
和 accordion-content-clicked
类中删除 transition
(你真的不想延迟点击和切换,只有内容改变)。JS函数changeTexts()
中的for..next
延迟 Accordion 的折叠。
关于javascript - 最大高度不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34704349/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!