最大高度转换不;不工作,工作缓慢
max-height transition doesn't work and works slow
我在为div展开设置动画时遇到问题。我的JQuery函数做了它应该做的事情,但动画没有出现。我试过transition : all
和transition : max-height
,但似乎都不起作用。当我想再次隐藏我的div时,也发生了一些非常奇怪的事情。在它消失之前似乎有某种延迟。这个延迟与动画的时间相匹配,但我不知道出了什么问题。请帮忙。
这是一把小提琴:https://jsfiddle.net/vbqc2c27/1/
不能从特定值(0px)到相对值(100%)设置动画。您需要使用特定的值:
更新的小提琴
$("p").on("click",function() {
if($("#test").css("max-height") == "0px") {
$("#test").css("max-height","100px");
}
else {
$("#test").css("max-height","0px");
}
});
将"100%"更改为"100px",效果良好。
当然,对于那些段落来说,100px还不够高(文本被剪裁)。因此,您可能需要添加一个函数来计算以像素为单位的自动高度。
更新的fiddle-无延迟的简单解决方案
修复延迟解决方案:
为元素设置三次贝塞尔(0,1,0,1)转换函数。
.text {
overflow: hidden;
max-height: 0;
transition: max-height 0.5s cubic-bezier(0, 1, 0, 1);
&.full {
max-height: 1000px;
transition: max-height 1s ease-in-out;
}
或者您可以使用比slideToggle()
函数更简单的函数:)
看看这个小提琴
JS
$("p").on("click",function() {
$("#test").slideToggle();
});
CSS
div {
display: none;
}
相关文章:
- Javascript:selenium Web驱动程序isDisplayed()不工作
- jQuery UI自动完成突然停止工作
- AngularJS UI路由器不能像ng路由器那样工作
- HTML5音频加载和播放获胜'我不能在iPad上工作
- JavaScript打印功能使日历停止工作
- Javascript.getHours()工作不正常
- 为什么这在IE中的工作方式与在Firefox中不同
- 视频HTML没有'无法在Internet Explorer 11上工作
- 扩展移相器按钮类不工作
- Firebase迁移-简单的Firebase.set没有'不再工作了——旧的还是新的
- 对iPad上的点击事件反应缓慢
- 谷歌地图不是以HTML显示,而是在JS Fiddle上工作
- 正在尝试使用if和else添加类,但无法正常工作
- Jquery FadeIn FadeOut 只工作一次
- Foreach无法在Typescript中工作
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- 为什么不是't窗口.恢复正常工作吗?(javascript/jquery)
- 最大高度转换不;不工作,工作缓慢
- Ajax调用工作缓慢.可以做得很快
- Node.js强大的文件上传工作缓慢的服务器