首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >阀体溢出隐藏单击

阀体溢出隐藏单击
EN

Stack Overflow用户
提问于 2016-10-14 17:22:56
回答 1查看 97关注 0票数 0

我的Html

代码语言:javascript
复制
<html>
...
<body>
 <div id="topContent">...</div>
 <div id="clickMe">Show TopContent</div>
...

</body>

通过单击div #clickMe上面的div #topContent与jQuery,它添加了一个溢出,因此我向主体添加了一个类,并使用toggleClass()隐藏溢出。

代码语言:javascript
复制
.hiddenOverflow { overflow:hidden }

JavaScript:

代码语言:javascript
复制
  $("#clickMe").click(function(){
    $("#topContent").slideToggle('slow');
    $('html,body').toggleClass('hiddenOverflow');
  });

问题是当我第一次单击时,它完全是slideDown,但是当我再次单击到slideUp时,溢出会添加到正文中,直到#topContent被隐藏,而当#topContent完全消失时,溢出消失。

如何防止在slideUp上不显示溢出?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-10-14 17:25:26

为什么不在CSS中声明溢出-x是隐藏的:

代码语言:javascript
复制
body {
    overflow-x: hidden;
}

在大多数情况下,您从不希望水平内容在正文中溢出。如果这不适合您的需要,可以将回调函数传递给slideToggle函数,该函数将在动画完成后执行:

代码语言:javascript
复制
$("#clickMe").click(function(){
    $("#topContent").slideToggle('slow', function() {
        $('html,body').toggleClass('hiddenOverflow');
    });
});

然而,这只会扭转你的问题。如果然后将其滑动打开,则类在打开后才会添加,很可能会导致相同的问题。为了防止这种情况,您必须跟踪#topContent div的状态(打开或关闭),并使用slideUpslideDown函数。slideUp将接受回调函数来移除类,其中slideDown不会接受函数,而是会立即切换类。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/40048777

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档