css Bootstrap 4崩溃有延迟

ubof19bj  于 2023-03-20  发布在  Bootstrap
关注(0)|答案(2)|浏览(142)

我在移动的视图上创建offcanvas导航菜单时遇到了一个问题,在添加class. show之前有0.3s的延迟。
我试着通过jquery添加自定义class .active,但是结果是一样的--即使这个类没有延迟地添加,这个类上的转换仍然延迟。

.collapse.active{
  transform: translateX(0%);
}

这很可能是由于添加和计算内联样式高度,我并不真正需要,因为我总是希望导航是100 vh。有没有办法削减或加快计算部分?
已尝试添加此代码,但完全没有帮助。

.collapsing {
-webkit-transition: all 0s ease-out;
-o-transition: all 0s ease-out;
transition: all 0s ease-out;
height:0 !important;
display: none;
}

引导链接(有延迟):https://www.bootply.com/9dFOT7Q2Ct

我在codepen上做了同样的事情,它工作得很好-它甚至没有向#navbarNav添加内联样式,所以可能是jquery的问题(我使用的是推荐的jquery-3.2.1)

Codepen链接(由于某种原因没有延迟):https://codepen.io/janheder/pen/rGLJLb

vql8enpb

vql8enpb1#

您可能会遇到延迟,因为 Bootstrap 在导航栏的show之前添加了一个collapsing类,以提供对动画的更多控制。
如果您正在寻求平稳过渡,我相信这可能会有所帮助:https://www.bootply.com/rPqvbgcCVj

body {
  overflow-x: hidden;
  -webkit-transition: margin .3s ease;
  -moz-transition: margin .3s ease;
  -o-transition: margin .3s ease;
  transition: margin .3s ease;
  width: 100%;
  margin: 0;
  font-family: -apple-system,
    BlinkMacSystemFont,
    "Segoe UI",
    Roboto,
    "Helvetica Neue",
    Arial,
    sans-serif;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: #212529;
  background-color: #fff;
}

.navbar-light .navbar-nav .nav-link {
  padding-right: 1.5rem;
  padding-left: 1.5rem;
  position: relative;
}

.navbar .menu-item.menu-item-has-children > .nav-link:after {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  position: absolute;
  right: 0;
  top: 50%;
  -ms-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  border-width: 4px 4px 0px 4px;
  border-color: #007bff transparent transparent transparent;
}
/* Added the following code and removed previous code */
.collapsing {
  transform: translateX(0%);
}

@media (max-width: 991px) {
  body.active {
    overflow: hidden;
    height: 100%;
    width: 100%;
    margin-left: -280px;
  }
  .collapse.active {
    transform: translateX(0%);
  }

  .navbar-collapse {
    position: fixed;
    right: 0px;
    top: 0px;
    display: block;
    transform: translateX(100%);
    height: 100vh;
    width: 280px;
    transition: transform .3s ease;
    overflow-y: scroll;
    background: #fff;
  }
  /* Added the following code */
  .active.collapsing {
    transform: translateX(0%);
  }

  .navbar .menu-item.menu-item-has-children > .nav-link:after {
    right: 1.5rem;
  }
}
ttygqcqt

ttygqcqt2#

对于想要修复bootstrap 5 offcanvas延迟的用户,这可以帮助您:

.offcanvas {
  transition : transform 0.15s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0s ease;
}

相关问题