我希望<li>
的文字位于#nav_bar
的中间。我试图通过margin
和padding
执行此操作,但我没有成功,有人知道如何做到这一点吗?
#nav_bar {
border: 2px solid black;
background-color: gray;
height: 40px;
}
li {
display: inline-block;
margin: 40px;
}
<div id="header">
<div id="nav_bar">
<ul>
<li>home</li>
<li>home 2</li>
<li>home 3</li>
<li>home 4</li>
<li>home 5</li>
</ul>
</div>
</div>
答案 0 :(得分:0)
重置ul
的默认padding
,将text-align: center
添加到ul
以使li
居中并添加一些左右{{} 1}}到padding
s。
li
&#13;
#nav_bar {
border: 2px solid black;
background-color: gray;
height: 40px;
}
ul {
text-align: center;
padding: 0;
}
li {
display: inline-block;
padding: 0 10px;
}
&#13;
答案 1 :(得分:0)
尝试text-align:center
http://jsfiddle.net/oktsheaw/
#nav_bar {
text-align:center;
border: 2px solid black;
background-color: gray;
height: 40px;
}
答案 2 :(得分:0)
试试这个:
#nav_bar {
border: 2px solid black;
background-color: gray;
height: 40px;
}
ul {
margin: 0;
padding: 0;
}
li {
display: inline;
margin; 0;
list-style: none;
line-height: 40px;
padding: 0 15px;
}
答案 3 :(得分:0)
你的意思是:http://codepen.io/anon/pen/KwaNwZ
CSS:
#nav_bar {
border: 2px solid black;
background-color: gray;
text-align:center;
}
li {
display: inline-block;
margin-left: 40px;
}
答案 4 :(得分:0)
您可以使用text-align:center
水平对齐。
#nav_bar {
border: 2px solid black;
background-color: gray;
height: 40px;
text-align:center;
}
ul {
padding: 0;
}
li {
display: inline-block;
}
<div id="header">
<div id="nav_bar">
<ul>
<li>home</li>
<li>home 2</li>
<li>home 3</li>
<li>home 4</li>
<li>home 5</li>
</ul>
</div>
</div>
您可以使用定位垂直对齐。
#nav_bar {
border: 2px solid black;
background-color: gray;
height: 40px;
width:100%;
position:relative;
}
ul {
padding: 0;
margin:0;
position: absolute;
top: 25%;
}
li {
display:inline-block;
}
<div id="header">
<div id="nav_bar">
<ul>
<li>home</li>
<li>home 2</li>
<li>home 3</li>
<li>home 4</li>
<li>home 5</li>
</ul>
</div>
</div>
我使用过定位,虽然其他形式同样有效。
#nav_bar {
border: 2px solid black;
background-color: gray;
height: 40px;
width:100%;
position:relative;
}
ul {
padding: 0;
margin:0;
position: absolute;
top: 25%;
left:25%;
}
li {
display:inline-block;
}
<div id="header">
<div id="nav_bar">
<ul>
<li>home</li>
<li>home 2</li>
<li>home 3</li>
<li>home 4</li>
<li>home 5</li>
</ul>
</div>
</div>
答案 5 :(得分:0)
由于元素在外面流动的高度移除了#nav_bar
的高度,它将垂直居中并添加text-align:center horizontal center
#nav_bar {
border: 2px solid black;
background-color: gray;
text-align: center;
}
li {
display: inline-block;
margin: 5px;
}
&#13;
<div id="header">
<div id="nav_bar">
<ul>
<li>home</li>
<li>home 2</li>
<li>home 3</li>
<li>home 4</li>
<li>home 5</li>
</ul>
</div>
</div>
&#13;