【发布时间】:2020-06-21 03:18:02
【问题描述】:
我在垂直导航栏中有一个带有子菜单的多重下拉菜单。我正在为这个元素使用 Bootstrap 3 和 JQuery,我想在每个列表上添加一个效果,这里是一个例子:
$('.dropdown').click(function(e) {
e.stopPropagation();
$(this).toggleClass('open');
});
$('.dropdown-submenu').click(function(e) {
e.stopPropagation();
$(this).find('.dropdown-menu').toggleClass('shown');
});
.sidebar-nav .dropdown-menu {
position: relative;
width: 100%;
padding: 0;
margin: 0;
border-radius: 0;
border: none;
background-color: #FFF;
box-shadow: none;
}
.sidebar-nav .dropdown-submenu {
position: relative;
width: 100%;
padding: 0;
margin: 0;
border-radius: 0;
border: none;
background-color: #FFF;
box-shadow: none;
}
.shown{
display: block !important;
}
.dropdown-submenu .dropdown-menu{background: #CCC;}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.12.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js" integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa" crossorigin="anonymous"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<ul class="nav sidebar-nav">
<li>
<a href="#">Option 1</a>
</li>
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown">Option 2 <span class="caret"></span></a>
<ul class="dropdown-menu" role="menu">
<li><a href="#">Option 2.1.</a></li>
<li><a href="#">Option 2.2.</a></li>
<li><a href="#">Option 2.3.</a></li>
<li class="dropdown-submenu">
<a href="#">Option 2.4. <span class="caret"></span></a>
<ul class="dropdown-menu" role="menu">
<li><a href="#">Option 2.4.1</a></li>
<li><a href="#">Option 2.4.2</a></li>
<li><a href="#">Option 2.4.3</a></li>
</ul>
</li>
<li class="dropdown-submenu">
<a href="#">Option 2.5. <span class="caret"></span></a>
<ul class="dropdown-menu" role="menu">
<li><a href="#">Option 2.4.1</a></li>
<li><a href="#">Option 2.4.2</a></li>
<li><a href="#">Option 2.4.3</a></li>
</ul>
</li>
</ul>
</li>
<li class="dropdown">
<a href="#">Option 3 <span class="caret"></span></a>
<ul class="dropdown-menu" role="menu">
<li><a href="#">Option 3.1.</a></li>
<li><a href="#">Option 3.2.</a></li>
<li><a href="#">Option 3.3.</a></li>
</ul>
</li>
<li>
<a href="#">Option 4</a>
</li>
</ul>
问题是当我点击菜单时,我希望每个列表都具有从下到上的淡入淡出效果,我尝试在第一个下拉菜单中添加:
.sidebar-nav .dropdown-menu { opacity: 0;
transform:translateY(60px);
transition: transform 0.85s cubic-bezier(0.165, 0.84, 0.44, 1) 0.075s,opacity 0.85s cubic-bezier(0.165, 0.84, 0.44, 1) 0.15s; }
.sidebar-nav .dropdown-menu.open .dropdown-menu{opacity: 1;transform:translateY(0px);}
但它不起作用。我该如何解决?
我需要你的帮助
【问题讨论】:
标签: javascript html jquery css dropdown