使用<ul>
+ <li>
:
http://jsfiddle.net/FsmcM/
使用<div>
+ <span>
:http://jsfiddle.net/z47LM/
是否可以显示<li>
的一半? (例如<div>
+ <span>
)
答案 0 :(得分:3)
从float:left
http://jsfiddle.net/FsmcM/2/
li
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<body>
<ul>
<li>1234567890</li>
<li>1234567890</li>
<li>1234567890</li>
</ul>
</body>
</html>
这是你的CSS with float:left注释掉了:
ul{
border:1px solid blue;
width:230px;
overflow:hidden;
list-style: none;
margin: 0;
padding: 0;
}
ul li{
/*float:left;*/
border:1px solid red;
height:20px;
display:inline;
word-break:break-all;
}
请注意,IE只会将文字换成空白字符。
答案 1 :(得分:2)
如果您删除float: left;
,那么它应该有用。
作为一个FYI,当您display:inline;
ul{
border:1px solid blue;
width:230px;
overflow:hidden;
list-style: none;
margin: 0;a
padding: 0;
}
ul li{
border:1px solid red;
height:20px;
display:inline;
word-break:break-all;
word-break: break-all;
}
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<body>
<ul>
<li>1234567890</li>
<li>1234567890</li>
<li>1234567890</li>
</ul>
</body>
</html>
答案 2 :(得分:2)
从float: left
中取出ul li
媒体资源。但是,如果您这样做,您可能会注意到每个li
元素之间有一点空格。这是因为HTML在li
标记之间有一些空格。
<ul>
... <li>A</li>
... <li>B</li>
</ul>
<!-- "..." denotes the spaces I'm talking about -->
要删除这些空格,您可以:
font-size
的{{1}}设置为0.然后,将ul
属性添加到font-size
。
http://jsfiddle.net/FsmcM/6/ 答案 3 :(得分:1)
您可以这样写:
ul {
border:1px solid blue;
width:230px;
list-style: none;
margin: 0;
padding: 0;
white-space:nowrap;
font-size:0;
}
ul li {
display:inline-block;
*display:inline; /*For IE*/
*zoom:1;
white-space:noraml;
font-size:16px;
border:1px solid red;
height:20px;
display:inline;
word-break:break-all;
}
答案 4 :(得分:1)
如果有以下更改,则看起来就像您的div
和span
示例:
HTML:
<ul>
<li>1234567890</li><li>1234567890</li><li>1234567890</li>
</ul>
的CSS:
ul{
border: 1px solid blue;
width: 210px;
list-style: none;
margin: 0;
padding: 0;
}
li{
border: 1px solid red;
height: 20px;
display: inline;
}
另见my example。