HTML5技术

css控制文字自动换行 - 1565783227

字号+ 作者:H5之家 来源:H5之家 2016-10-15 15:00 我要评论( )

自动换行问题,正常字符的换行是比较合理的,而连续的数字和英文字符常常将容器撑大,挺让人头疼,下面介绍的是 CSS 如何实现换 行的方法 对于div,p等块级元素 正常文字的换行(亚洲文字和非亚洲文字)元素拥有默认的white-space:normal,当定义的宽度之后自动换行 h

自动换行问题,正常字符的换行是比较合理的,而连续的数字和英文字符常常将容器撑大,挺让人头疼,下面介绍的是CSS如何实现换

行的方法

对于div,p等块级元素
正常文字的换行(亚洲文字和非亚洲文字)元素拥有默认的white-space:normal,当定义的宽度之后自动换行

html

正常文字的换行(亚洲文字和非亚洲文字)元素拥有默认的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;}

abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111

效果:可以实现换行

2.(Firefox浏览器)连续的英文字符和阿拉伯数字的断行,Firefox的所有版本的没有解决这个问题,
我们只有让超出边界的字符隐藏或者,给容器添加滚动条

#wrap

{word-break:break-all; width:200px; overflow:auto;}

abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111

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

对于table

1. (IE浏览器)使用 table-layout:fixed;强制table的宽度,多余内容隐藏

<table> <tr> <td>abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss </td> </tr> </table>

效果:隐藏多余内容

2.(IE浏览器)使用 table-layout:fixed;强制table的宽度,
内层td,th采用word-break : break-all;或者word-wrap : break-word ;换行

 

<table> <tr> <td>abcdefghigklmnopqrstuvwxyz 1234567890   </td> <td>abcdefghigklmnopqrstuvwxyz 1234567890 </td> </tr> </table>

 

效果:可以换行

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> <tr> <td>abcdefghigklmnopqrstuvwxyz1234567890</td> <td>abcdefghigklmnopqrstuvwxyz1234567890</td> </tr> </table>

效果:隐藏多于内容

5.(Firefox浏览器) 在td,th中嵌套div,p等采用上面提到的对付Firefox的方法
运行代码框100素材网
最后,这种现象出现的几率很小,但是不能排除网友的恶搞。如果

有什么问题请到在下面留言

下面是提到的例子的效果

  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>字符换行   </title> <style type="text/css"> table,td,th,div { border:1px green solid;} code { font-family:"Courier New", Courier, monospace;}   </style> </head> <body> <h1><code>div</code></h1> <h1><code>All white-space:normal;</code></h1> <div>Wordwrap still occurs in a td element that has its WIDTH attribute set to a value smaller than the unwrapped content of the cell, even if the noWrap property is set to true. Therefore, the WIDTH attribute takes precedence over the noWrap property in this scenario</div>   <h1><code>IE word-wrap : break-word ;</code></h1> <div>abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div> <h1><code>IE word-break:break-all;</code></h1> <div>abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div>   <h1><code>Firefox/ word-break:break-all; overflow:auto;</code></h1> <div>abcdefghijklmnabcdefghijklmnabcdefghijkl mn111111111</div> <h1><code>table</code></h1> <h1><code>table-layout:fixed;</code></h1> <table> <tr> <td>abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss</td> </tr> </table> <h1><code>table-layout:fixed; word-break : break-all; word-wrap : break-word ;</code></h1> <table> <tr> <td>abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss</td> <td>abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss</td> </tr> </table> <h1><code>FF table-layout:fixed; overflow:hidden;</code></h1> <table> <tr> <td>abcdefghigklmnopqrstuvwxyz1234567890</td> <td>abcdefghigklmnopqrstuvwxyz1234567890</td> </tr> </table> </body> </html>

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • 【菜鸟玩Linux开发】通过MySQL自动同步刷新Redis - zhxilin

    【菜鸟玩Linux开发】通过MySQL自动同步刷新Redis - zhxilin

    2016-10-03 16:00

  • 关于IOS中safari下的select下拉菜单,文字过长不换行的问题 - 梦影雾花,尽是虚空

    关于IOS中safari下的select下拉菜单,文字过长不换行的问题 - 梦影雾

    2016-09-27 17:00

  • 使用 Entity Framework Core 时,通过代码自动 Migration - JRoger

    使用 Entity Framework Core 时,通过代码自动 Migration - JRoger

    2016-09-04 17:00

  • html5 js控制音乐播放 - 裂光逝

    html5 js控制音乐播放 - 裂光逝

    2016-08-20 11:00

网友点评
x