我有一个简单的问题,我试图使用jQuery切换创建一个可扩展的淹死。
我可以让整体功能正常工作,但由于某种原因,我的子菜单超过了主菜单。.我相信这与属性填充顶部:70px有关;
我正在尝试重新创建此处找到的 NAV 菜单:http://adidasdesignstudios.com/
.HTML:
<header class="menu">
<div class="sub">
<nav>
<ul class="sub-options">
<li>
<div>
<a href="#all_crafted">1_</a>
<section><br>Check out product designs.</section>
</div>
</li>
<li>
<div>
<a href="#all_about">2_</a>
<section><br>Find out more about.</section>
</div>
</li>
<li>
<div>
<a href="#all_in">3_</a>
<section><br>Learn design.</section>
</div>
</li>
<li>
<div>
<a href="#all_jobs">4_</a>
<section><br>View current job opportunities.</section>
</div>
</li>
<li>
<div>
<a href="#all_cities">5_</a>
<section><br>See our locations.</section>
</div>
</li>
<li>
<div>
<a href="#all_academy">6_</a>
<section><br>Learn more.</section>
</div>
</li>
</ul>
</nav>
</div>
</header>
.CSS:
.menu {
color:#515151;
height:70px;
left:0;
width:100%;
background-color:rgba(19,19,19,0.8);
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#CC131313,endColorstr=#CC131313);
top:0;
position:fixed;
zoom:1;
margin:0 auto;
display:block;
padding-top:70px;
.sub {
background:#fff;
position:absolute;
z-index:2;
width:100%;
border-radius:3px;
/*box-shadow:0 2px 4px #ddd;*/
border:1px solid #ddd;
display:none;
/*padding:40px 0 3px;*/
}
j查询:
$(".menu").hover(
function(){$(".sub").slideToggle(400);},
function(){$(".sub").hide();}
);
我认为我很接近,但任何帮助将不胜感激。
我会单独用css(nno jQuery)修复它:示例=>jsfiddle
此外,您的代码中缺少"}":
.menu {
color:#515151;
height:70px;
left:0;
width:100%;
background-color:rgba(19, 19, 19, 0.8);
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#CC131313, endColorstr=#CC131313);
top:0;
position:fixed;
zoom:1;
margin:0 auto;
display:block;
padding-top:70px;
**}**
.sub {
background:#fff;
position:absolute;
z-index:2;
width:100%;
border-radius:3px;
/*box-shadow:0 2px 4px #ddd;*/
border:1px solid #ddd;
display:none;
/*padding:40px 0 3px;*/
}
不是完美的答案,但是当我尝试时,这有效:
.menu {
color:#515151;
height:70px;
left:0;
width:100%;
background-color:rgba(19, 19, 19, 0.8);
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#CC131313, endColorstr=#CC131313);
top:0;
position:fixed;
zoom:1;
margin:0 auto;
display:block;
}
.sub {
background:#fff;
position:absolute;
z-index:2;
width:100%;
border-radius:3px;
/*box-shadow:0 2px 4px #ddd;*/
border:1px solid #ddd;
display:none;
/*padding:40px 0 3px;*/
top: 70px;
}
我刚刚从 .menu 中删除了"paddign-top:70px",并在 .sub 中添加了"top:70px"
在类.sub
中,将其位置设置为 position:absolute
但没有指定位置。
尝试在类.sub
中添加top:100%;
。这样,它将在您的菜单下方。所以不再重叠。