使用下面的CSS,我试图在页面顶部创建一个导航栏(固定在顶部),但不是它位于屏幕的绝对左侧,我希望它居中。
ul#list-nav
{
position:fixed;
top:0;
left:0;
margin:auto;
padding:0px;
width:100%;
height:28px;
font-size:120%;
display:inline;
text-decoration:none;
list-style:none;
background-color: #1F1F1F;
border:none;
z-index:1000;
}
ul#list-nav li
{
float:left;
}
ul#list-nav a
{
background-color:#1F1F1F;
color:#C4C4C4;
/*display:block;*/
padding:5px 15px;
text-align: center;
text-decoration:none;
font-size:14px;
}
ul#list-nav a:hover
{
background-color:#4D4D4D;
text-decoration:none;
}
ul#list-nav a:active
{
background-color:#9C9C9C;
text-decoration:none;
}
到目前为止尝试使其成为垂直列表,或使按钮从中心开始(而不是居中)。我怎么能做到这一点?
编辑:下面是HTML ...此列表是唯一被设置样式的内容。
<ul id="list-nav">
<li><a href="/ourbs/index.php">Home</a></li>
<li><a href="/ourbs/categories/projects.php">Projects</a></li>
<li><a href="/ourbs/categories/opinion.php">Opinion</a></li>
<li><a href="/ourbs/categories/humour.php">Humour</a></li>
<li><a href="/ourbs/categories/games.php">Games</a></li>
<li><a href="/ourbs/categories/movies.php">Movies</a></li>
<li><a href="/ourbs/categories/tvshows.php">TV Shows</a></li>
</ul>
EDIT2:如果这有帮助,这里有一个jsFiddle http://jsfiddle.net/752jU/1/
答案 0 :(得分:3)
您只需要一个包装器div
即可完成此操作......
注意:使用display: inline
我的回答也是good in IE 6 & 7,如果重要的话。
<强> CSS:强>
div#wrapper {
position: fixed;
top: 0;
width: 100%;
text-align: center;
height:28px;
background-color: #1F1F1F;
border: none;
z-index: 1000;
}
ul#list-nav {
padding: 0px;
width: auto;
font-size: 120%;
text-decoration: none;
list-style: none;
}
ul#list-nav li {
display: inline;
}
<强> HTML:强>
<div id="wrapper">
<ul id="list-nav">
<li><a href="/index.php">Home</a></li>
<li><a href="/ourbs/categories/projects.php">Projects</a></li>
<li><a href="/categories/opinion.php">Opinion</a></li>
<li><a href="/categories/humour.php">Humour</a></li>
<li><a href="/categories/games.php">Games</a></li>
<li><a href="/categories/movies.php">Movies</a></li>
<li><a href="/categories/tvshows.php">TV Shows</a></li>
</ul>
</div>
答案 1 :(得分:2)
您需要在3个嵌套的div中插入列表:
在你的css中:
div#container1
{
position:fixed;
top:0;
left:0;
width:100%
}
div#container2
{
margin-left:auto;
margin-right:auto;
text-align: center;
}
div#container3
{
display:inline-block;
}
然后在你的html:
<div id="container1">
<div id="container2">
<div id="container3">
<ul id="list-nav">
...
</ul>
</div>
</div>
</div>
有关正确居中的代码版本,请参阅http://jsfiddle.net/jZQ4v/
答案 2 :(得分:1)
使用:
#list-nav {
padding: 0px;
height: 28px;
font-size: 120%;
margin: auto;
text-align: center;
list-style: none;
background-color: #1F1F1F;
border: none;
z-index: 1000;
}
#list-nav li {
display: inline;
text-align: center;
}
#list-nav a {
color: #C4C4C4;
background-color: #1F1F1F;
display: inline;
text-decoration: none;
padding: 5px 15px;
font-size: 14px;
}
#list-nav a:hover {
background-color: #4D4D4D;
text-decoration: none;
}
#list-nav a:active {
background-color: #9C9C9C;
text-decoration: none;
}
我删除了所有不会以任何方式改变菜单的不必要的编码。
在此处观看现场演示:http://jsfiddle.net/YFDeX/1/
修改:改进与IE6 +的兼容性
希望这有帮助。