我通常将显示 block 放在链接上,以使按钮的所有 div 都处于事件状态,而不仅仅是文本。但在这种情况下,我需要在 ul
li
中使用 display:inline-block
我认为这会禁用其他显示 block ?如何使所有 li
都处于事件状态,而不仅仅是其中的文本?
示例如下:http://jsfiddle.net/mPGDe/
HTML:
<ul class="menu">
<li><a href="#">first</a></li>
<li><a href="#">second</a></li>
<li><a href="#l">third</a></li>
</ul>
CSS:
ul {
margin:40px auto;
list-style-type:none;
padding:0;
text-align: center;
}
ul li {
position: relative;
padding: 7px 17px;
margin-right: 10px;
background-color: #f2f2f2;
display: inline-block; /* does it disable display block? */
}
ul li a {
display:block;/* usually to make active all the zone, but here it does not work */
}
将填充放在 a
而不是 li
ul li {
position: relative;
margin-right: 10px;
background-color: #f2f2f2;
display: inline-block; /* does it disable display block? */
}
ul li a {
padding: 7px 17px;
display:block;/* usually to make active all the zone, but here it does not work */
}
演示在 http://jsfiddle.net/gaby/mPGDe/1/
我是一名优秀的程序员,十分优秀!