如何用CSS实现html中table的自动换行

html-css015

如何用CSS实现html中table的自动换行,第1张

HTML里面加了一个样式属性:

word-break: break-all,可以实现表格的自动换行,具体参考代码如下:

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/htmlcharset=utf-8" />

<title>table内的td内容不换行</title>

<style type="text/css">

<!--

body{ font-size:12px}

.breakLine{word-break: break-all}

-->

</style>

</head>

<body>

<table width="400">

<tr>

<td width="90" height="30">处理人工号:</td>

<td width="410" class="breakLine">001156,001157,001145,001149,001178,001123,001140,001167,001168,001134,001135</td>

</tr>

</table>

</body>

</html>

word-break属性简单介绍如下:

语法:word-break : normal | break-all | keep-all

取值:

normal :  默认值。允许在词间换行

break-all :  该行为与亚洲语言的 normal 相同。也允许非亚洲语言文本行的任意字内断开。该值适合包含一些非亚洲文本的亚洲文本

keep-all :  与所有非亚洲语言的 normal 相同。

大家都知道连续的英文或数字能是容器被撑大,不能根据容器的大小自动换行,下面是

CSS如何将他们换行的方法!

对于div

1.(IE浏览器)white-space:normal

word-break:break-all这里前者是遵循标准。

#wrap{white-space:normal

width:200px

}

或者

#wrap{word-break:break-allwidth:200px}

ddd1111111111111111111111111111111111

效果:可以实现换行

2.(Firefox浏览器)white-space:normal

word-break:break-alloverflow:hidden同样的FF下也没有很好的实现方法,只能隐藏或者加滚动条,当然不加滚动条效果更好!

#wrap{white-space:normal

width:200px

overflow:auto}

或者

#wrap{word-break:break-allwidth:200px

overflow:auto

}

ddd1111111111111111111111111111111111111111

效果:容器正常,内容隐藏

对于table

1.

(IE浏览器)使用样式table-layout:fixed;

.tb{table-layout:fixed}

abcdefghigklmnopqrstuvwxyz

1234567890

效果:可以换行

2.(IE浏览器)使用样式table-layout:fixed与nowrap

.tb

{table-layout:fixed}

abcdefghigklmnopqrstuvwxyz

1234567890

效果:可以换行

3.

(IE浏览器)在使用百分比固定td大小情况下使用样式table-layout:fixed与nowrap

.tb{table-layout:fixed}

abcdefghigklmnopqrstuvwxyz

1234567890

abcdefghigklmnopqrstuvwxyz

1234567890

效果:两个td均正常换行

4.(Firefox浏览器)在使用百分比固定td大小情况下使用样式table-layout:fixed与nowrap,并且使用div

.tb

{table-layout:fixed}

.td

{overflow:hidden}

abcdefghigklmnopqrstuvwxyz

1234567890

abcdefghigklmnopqrstuvwxyz

1234567890

这里单元格宽度一定要用百分比定义

效果:正常显示,但不能换行(注:在FF下还没有能使容器内容换行的好方法,只能用overflow将多出的内容隐藏,以免影响整体效果)

<td>是否自动换行与宽度无关,换句话说你改变table的宽度,并不影响td是否换行的属性。

一般情况下换行与文本有关,例如一般英语不允许单词换行,但是可以使用下面的CSS属性改变他们:

word-wrap : normal | break-word

参数:

normal :  允许内容顶开指定的容器边界

break-word

:  内容将在边界内换行。如果需要,词内换行(word-break)也行发生

word-break : normal | break-all | keep-all

参数:

normal :

 依照亚洲语言和非亚洲语言的文本规则,允许在字内换行

break-all :

 该行为与亚洲语言的normal相同。也允许非亚洲语言文本行的任意字内断开。该值适合包含一些非亚洲文本的亚洲文本

keep-all :

 与所有非亚洲语言的normal相同。对于中文,韩文,日文,不允许字断开。适合包含少量亚洲文本的非亚洲文本

说明:

设置或检索对象内文本的字内换行行为。尤其在出现多种语言时。

对于中文,应该使用break-all 。

对应的脚本特性为wordBreak。请参阅我编写的其他书目。

white-space : normal | pre |

nowrap

参数:

normal :

 默认处理方式

pre :  用等宽字体显示预先格式化的文本。不合并字间的空白距离和进行两端对齐。参阅pre对象

nowrap :  强制在同一行内显示所有文本,直到文本结束或者遭遇br对象。参阅td,div等对象的nowrap属性(特性)