我正在尝试为我正在开发的网站创建一个解决方案,其中菜单和子菜单水平居中,但 div 扩展到整个页面宽度。
首先,这是一个示例 HTML:
<div id="menu-container" class="full-width">
<nav id="nav1" class="normal-width">
<ul class="main-menu">
<li id="item1">
<a href="#">item 1</a>
<ul class="sub-menu">
<li id="item11">
<a href="#">item 1.1</a>
</li>
<li id="item12">
<a href="#">item 1.2</a>
</li>
<li id="item13">
<a href="#">item 1.3</a>
</li>
</ul>
</li>
<li id="item2">
<a href="#">item 2</a>
<ul class="sub-menu">
<li id="item21">
<a href="#">item 2.1</a>
</li>
<li id="item22">
<a href="#">item 2.2</a>
</li>
</ul>
</li>
<li id="item3">
<a href="#">item 3</a>
</li>
</ul>
</nav>
</div>
这个菜单的 CSS 是:
.full-width {
width: 100%;
}
.normal-width {
width: 1024px;
margin: 0 auto 0 auto;
}
a {
color: black;
text-decoration: none;
}
.clear {
clear: both;
}
.main-menu {
list-style-type: none;
margin: 0;
padding: 0;
position: relative;
background-color: red;
}
.main-menu > li {
float:left;
margin-right:2em;
}
.sub-menu {
list-style-type: none;
margin: 0;
padding: 0;
display:none;
background-color: orange;
}
.sub-menu li {
float:left;
margin-right:2em;
}
.main-menu > li.selected {
background-color:orange;
}
.main-menu > li.selected .sub-menu {
display:block;
position:absolute;
left:0;
right:0;
}
相关的 jQuery 是:
// Add a clear div to allow adding background color to main-menu
$(".main-menu").append("<div class='clear'></div>");
// Make the first class selected
$(".main-menu > li:first").addClass("selected");
// Switch the selected class
$(".main-menu > li").click(function() {
$(".selected").removeClass("selected");
$(this).addClass("selected");
});
// Disable menu links
$(".main-menu > li > a").click(function(e) {
e.preventDefault();
});
所有这些都很好,很漂亮,并且创建了一个适当的水平菜单。我正在努力并且无法创建的是您在这张图片中看到的内容:
请注意有关图片的以下几点:
图片周围的黑色粗边框是网页全尺寸和宽度(即浏览器窗口边框)
中间的细垂直紫色线不可见,它们在图片中显示内容将在哪里,即没有内容会越过紫色线的最左侧或最右侧
顶级菜单项具有红色背景
子菜单将出现在橙色背景的区域中
现在,问题:
请注意红色和黄色背景如何延伸到网页边缘,而这些页面的项目却出现在紫色线条内的内容区域内。这就是我想要实现但无法实现的。我无法将背景扩展到网络浏览器的边缘(即整页宽度)。我的解决方案将红色和橙色背景居中。