关于强制不换行、强制换行的话题在网上已经被讨论了无数次,但我发现都不够全面,没有充分考虑各类浏览器、各类标签等状况,以至不兼容,因此我再来讲说。因为 div 和 p 在本文的讨论中,效果相同,因此省略 p。
文中“没有指定宽度的 td”是指:为 table 指定了宽度,但没有给 td 指定宽度。
强制不换行
div,
td
{
white-space:nowrap;
}
这点在 Firefox 的 div 和 td 中,以及 IE 的 div 中,均没有问题。在 IE 的 td 中却很复杂:
若是没有为 td 指定宽度,则上述代码仍然有效。
若是为 td 指定了宽度,而且文字中无标点、无空格,上述代码再也不有效。能够加 word-break:keep-all; 解决,这是 CSS3 的内容,不过是 IE 最早提出的,因此 IE6 中也支持。
若是为 td 指定了宽度,而且文字中有标点或空格。能够在文字与 td 之间套一层 div 加以解决。
综合起来,为了简单,使用:
div
{
white-space:nowrap;
}
只是为了兼容 IE 的 td 的不一样状况,在文字与 td 之间套一层 div。
强制换行
强制换行是为了遇到一些超长的连续字符串(好比 aaaaaaaaaaaaa)时不撑大布局。
div,
td
{
word-break:break-all;
}
word-wrap:break-word; 兼容性不够广,因此咱们使用的是 word-break:break-all;。上述代码兼容于 IE、Chrome 的 div、指定宽度的 td、没有指定宽度的 td,很是不错,遗憾的是 Firefox 中不支持这个属性,因此无效果,为了避免让其挤乱表格,能够加 overflow:hidden 来凑合着解决。
知其然知其因此然
上面介绍了三种属性:
white-space : normal | nowrap
word-wrap : normal | break-word
word-break : normal | break-all | keep-all
white-space
空白的处理方式,不止两个属性值,但在 IE6 中只支持这两个,因此不介绍其余的。
normal 多个连续英文空格压缩为一个英文空格显示,在空白处可换行。
nowrap 强制在同一行内显示全部文本,直到文本结束或者遭遇 br 对象。
word-wrap
内容超过容器边界时是否断开转行。
normal 容许(只是容许,不是必须)内容顶开指定的容器边界。
break-word 内容将在边界内换行。
word-break
换行的方式。
normal 英文在标点和空白处换行,中文在任何地方换行。
break-all 英文和中文都在任何地方换行,好比从一个英文单词的中间拆开换行。
keep-all 英文和中文都在标点和空白处换行。
用css控制td强制换行 2008-10-23 16:11 即使是给td限定的宽度,可是若是里面的内容是连续的,IE就认为是一个单词,不会换行。控制td换行的css样式:style="word-wrap:break-word;word- break:break-all;"
1<table width="100%" border="0" cellspacing="1" cellpadding="0">
2 <tr>
3 <td width="25%" style="word-wrap:break-word;word-break:break-all;" valign="bottom" >
4 文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息文本测试信息</td>
5 </tr>
6</table>
解决长串英文字母不能自动换行的问题和td中汉字自动换行 & CSS强制不换行
编程心得 2009-10-15 10:24 阅读85 评论0 字号: 大大 中中 小小 例如:aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa不能处理自动换行,将表格伸的很长很长,而汉字字符却能够自动换行。
缘由是:
英文字母之间若是没有空格,系统认为是一个单词,就不会自动换行。汉字就没有这种状况。
解决办法:
用表格把要显示的内容装起来。
在<table>标签中加入“style='TABLE-LAYOUT: fixed'”,
在须要强制单词换行的<td>标签中加入“style='word-WRAP: break-word'”。
这样就能够了。
Div 中 :
div 实现长英文字母自动换行CSS
IE浏览器
#wrap{white-space:normal; width:200px; }
或者
#wrap{word-break:break-all;width:200px;}
Firefox浏览器
#wrap{white-space:normal; width:200px; overflow:auto;}
或者
#wrap{word-break:break-all;width:200px; overflow:auto; }
二、不设置单元格宽度,但汉字会自动换行:
解决方法: <table style='word-break:keep-all'>
CSS强制不换行
word-break属性, keep-all;不换行。。 IE7和FF , IE6 不行。。
white-space: nowrap; IE6 及一下版本
顺便写下语法:
语法:
white-space : normal | pre | nowrap
取值:
normal : 默认值。默认处理方式。文本自动处理换行。假如抵达容器边界内容会转到下一行
pre : 换行和其余空白字符都将受到保护。这个值须要IE6+或者 !DOCTYPE 声明为 standards-compliant mode 支持。若是 !DOCTYPE 声明没有指定为 standards-compliant mode ,此属性可使用,可是不会发生做用。结果等同于 normal 。参阅 pre 对象
nowrap : 强制在同一行内显示全部文本,直到文本结束或者遭遇 br 对象。参阅 noWrap 属性
说明:
设置或检索对象内空格字符的处理方式。
空格字符,像换行,空格,TAB,在HTML文档中默认的是被忽略的。当此属性设置为 normal 或者 nowrap 时,你可使用不换行空格的命名实体 来添加空格,用 br 元素来添加换行。此属性对你使用文档对象模型(DOM)操做的内容的影响与其对IE显示内容的影响同样。
此属性做用于块对象。
此属性对于 currentStyle 对象而言是只读的。对于其余对象而言是可读写的。
对应的脚本特性为 whiteSpace 。css