2023年6月20日发(作者:)

CSS样式⾃动换⾏(强制换⾏)对于div,p等块级元素

正常⽂字的换⾏(亚洲⽂字和⾮亚洲⽂字)元素拥有默认的 white-space:normal ,当定义的宽度之后⾃动换⾏html:< div id ="wrap" >正常⽂字的换⾏(亚洲⽂字和⾮亚洲⽂字)元素拥有默认的white-space:normal,当定义 css:#wrap{white-space:normal; width:200px; }

1.(IE浏览器)连续的英⽂字符和阿拉伯数字,使⽤word-wrap : break-word ;或者word-break:break-all;实现强制断⾏#wrap{ word-break: break-all; width: 200px;}或者#wrap{ word-wrap: break-word; width: 200px;}html:< div id ="wrap" >abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111 效果:可以实现换⾏

2.(Firefox浏览器)连续的英⽂字符和阿拉伯数字的断⾏,Firefox的所有版本的没有解决这个问题,我们只有让超出边界的字符隐藏或者,给容器添加滚动条#wrap{word-break:break-all; width:200px; overflow:auto;}html:< div id ="wrap" >abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111 效果:容器正常,内容隐藏

对于table1. (IE浏览器)使⽤ table-layout:fixed;强制table的宽度,多余内容隐藏< table style ="table-layout:fixed" width ="200" >

< tr >

< td >abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss

效果:隐藏多余内容2.(IE浏览器)使⽤ table-layout:fixed;强制table的宽度,内层td,th采⽤word-break : break-all;或者word-wrap : break-word ;换⾏< table width ="200" style ="table-layout:fixed;" >

< tr >

< td width ="25%" style ="word-break : break-all; " >abcdefghigklmnopqrstuvwxy 1234567890

< td style ="word-wrap : break-word ;" >abcdefghigklmnopqrstuvwxyz 1234567890

效果:可以换⾏3. (IE浏览器)在td,th中嵌套div,p等采⽤上⾯提到的div,p的换⾏⽅法 ( 技巧 )4.(Firefox浏览器)使⽤ table-layout:fixed;强制table的宽度,内层td,th采⽤word-break : break-all;或者word-wrap : break-word ;换⾏,使⽤overflow:hidden;隐藏超出内容,这⾥overflow:auto;⽆法起作⽤< table style ="table-layout:fixed" width ="200" >

< tr >

< td width ="25%" style ="word-break : break-all; overflow:hidden; " >abcdefghigklmnopqrstuvwxyz1234567890

< td width ="75%" style ="word-wrap : break-word; overflow:hidden; " >abcdefghigklmnopqrstuvwxyz1234567890

效果:隐藏多于内容

++++++++++++++++++++++++++++++++++++++++++++

CSS样式

强制不换⾏

CSS样式

强制不换⾏

div{

white-space: nowrap;

}

⾃动换⾏

div{

word-wrap: break-word;

word-break: normal;

}

强制英⽂单词断⾏

div{

word-break: break-all;

}

CSS设置不转⾏:

overflow:hidden 隐藏

white-space:normal 默认

pre 换⾏和其他空⽩字符都将受到保护 nowrap 强制在同⼀⾏内显⽰所有⽂本,直到⽂本结束或者遭遇 br 对象

设置强⾏换⾏:

word-break:

normal ; 依照亚洲语⾔和⾮亚洲语⾔的⽂本规则,允许在字内换⾏

break-all :  该⾏为与亚洲语⾔的normal相同。也允许⾮亚洲语⾔⽂本⾏的任意字内断开。该值适合包含⼀些⾮亚洲⽂本的亚洲⽂本

keep-all :  与所有⾮亚洲语⾔的normal相同。对于中⽂,韩⽂,⽇⽂,不允许字断开。适合包含少量亚洲⽂本的⾮亚洲⽂本与之间的⾼度解决办法

英⽂不换⾏

CSS⾥加上 word-break: break-all; 问题解决。这个问题只有IE才有,在FF下测试,FF可以⾃⼰加滚动条,这样也不影响效果

建议⼤家做Skin时,记得在body⾥加 word-break: break-all; 这样可以解决IE的框架被英⽂撑开的问题

以下引⽤word-break的说明, 注意word-break 是IE5+专有属性

语法:

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

参数:

normal :  依照亚洲语⾔和⾮亚洲语⾔的⽂本规则,允许在字内换⾏

break-all :  该⾏为与亚洲语⾔的normal相同。也允许⾮亚洲语⾔⽂本⾏的任意字内断开。该值适合包含⼀些⾮亚洲⽂本的亚洲⽂本

keep-all :  与所有⾮亚洲语⾔的normal相同。对于中⽂,韩⽂,⽇⽂,不允许字断开。适合包含少量亚洲⽂本的⾮亚洲⽂本

说明:

设置或检索对象内⽂本的字内换⾏⾏为。尤其在出现多种语⾔时。

对于中⽂,应该使⽤break-all 。

对应的脚本特性为wordBreak。请参阅我编写的其他书⽬。 ⽰例:

div {word-break : break-all; }

2023年6月20日发(作者:)

CSS样式⾃动换⾏(强制换⾏)对于div,p等块级元素

正常⽂字的换⾏(亚洲⽂字和⾮亚洲⽂字)元素拥有默认的 white-space:normal ,当定义的宽度之后⾃动换⾏html:< div id ="wrap" >正常⽂字的换⾏(亚洲⽂字和⾮亚洲⽂字)元素拥有默认的white-space:normal,当定义 css:#wrap{white-space:normal; width:200px; }

1.(IE浏览器)连续的英⽂字符和阿拉伯数字,使⽤word-wrap : break-word ;或者word-break:break-all;实现强制断⾏#wrap{ word-break: break-all; width: 200px;}或者#wrap{ word-wrap: break-word; width: 200px;}html:< div id ="wrap" >abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111 效果:可以实现换⾏

2.(Firefox浏览器)连续的英⽂字符和阿拉伯数字的断⾏,Firefox的所有版本的没有解决这个问题,我们只有让超出边界的字符隐藏或者,给容器添加滚动条#wrap{word-break:break-all; width:200px; overflow:auto;}html:< div id ="wrap" >abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111 效果:容器正常,内容隐藏

对于table1. (IE浏览器)使⽤ table-layout:fixed;强制table的宽度,多余内容隐藏< table style ="table-layout:fixed" width ="200" >

< tr >

< td >abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss

效果:隐藏多余内容2.(IE浏览器)使⽤ table-layout:fixed;强制table的宽度,内层td,th采⽤word-break : break-all;或者word-wrap : break-word ;换⾏< table width ="200" style ="table-layout:fixed;" >

< tr >

< td width ="25%" style ="word-break : break-all; " >abcdefghigklmnopqrstuvwxy 1234567890

< td style ="word-wrap : break-word ;" >abcdefghigklmnopqrstuvwxyz 1234567890

效果:可以换⾏3. (IE浏览器)在td,th中嵌套div,p等采⽤上⾯提到的div,p的换⾏⽅法 ( 技巧 )4.(Firefox浏览器)使⽤ table-layout:fixed;强制table的宽度,内层td,th采⽤word-break : break-all;或者word-wrap : break-word ;换⾏,使⽤overflow:hidden;隐藏超出内容,这⾥overflow:auto;⽆法起作⽤< table style ="table-layout:fixed" width ="200" >

< tr >

< td width ="25%" style ="word-break : break-all; overflow:hidden; " >abcdefghigklmnopqrstuvwxyz1234567890

< td width ="75%" style ="word-wrap : break-word; overflow:hidden; " >abcdefghigklmnopqrstuvwxyz1234567890

效果:隐藏多于内容

++++++++++++++++++++++++++++++++++++++++++++

CSS样式

强制不换⾏

CSS样式

强制不换⾏

div{

white-space: nowrap;

}

⾃动换⾏

div{

word-wrap: break-word;

word-break: normal;

}

强制英⽂单词断⾏

div{

word-break: break-all;

}

CSS设置不转⾏:

overflow:hidden 隐藏

white-space:normal 默认

pre 换⾏和其他空⽩字符都将受到保护 nowrap 强制在同⼀⾏内显⽰所有⽂本,直到⽂本结束或者遭遇 br 对象

设置强⾏换⾏:

word-break:

normal ; 依照亚洲语⾔和⾮亚洲语⾔的⽂本规则,允许在字内换⾏

break-all :  该⾏为与亚洲语⾔的normal相同。也允许⾮亚洲语⾔⽂本⾏的任意字内断开。该值适合包含⼀些⾮亚洲⽂本的亚洲⽂本

keep-all :  与所有⾮亚洲语⾔的normal相同。对于中⽂,韩⽂,⽇⽂,不允许字断开。适合包含少量亚洲⽂本的⾮亚洲⽂本与之间的⾼度解决办法

英⽂不换⾏

CSS⾥加上 word-break: break-all; 问题解决。这个问题只有IE才有,在FF下测试,FF可以⾃⼰加滚动条,这样也不影响效果

建议⼤家做Skin时,记得在body⾥加 word-break: break-all; 这样可以解决IE的框架被英⽂撑开的问题

以下引⽤word-break的说明, 注意word-break 是IE5+专有属性

语法:

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

参数:

normal :  依照亚洲语⾔和⾮亚洲语⾔的⽂本规则,允许在字内换⾏

break-all :  该⾏为与亚洲语⾔的normal相同。也允许⾮亚洲语⾔⽂本⾏的任意字内断开。该值适合包含⼀些⾮亚洲⽂本的亚洲⽂本

keep-all :  与所有⾮亚洲语⾔的normal相同。对于中⽂,韩⽂,⽇⽂,不允许字断开。适合包含少量亚洲⽂本的⾮亚洲⽂本

说明:

设置或检索对象内⽂本的字内换⾏⾏为。尤其在出现多种语⾔时。

对于中⽂,应该使⽤break-all 。

对应的脚本特性为wordBreak。请参阅我编写的其他书⽬。 ⽰例:

div {word-break : break-all; }