原来CSS的DIV换行是有问题的

最近在学CSS, 想改改现在这个blog的模板,所以不断的在本机的试验,一步一步的把这个blog的CSS拆解在自己的例子里,但发现了好多问题,当输出连续字母或者数字时,会把div撑大的,还有图片也是,原来CSS里边都多多问题要去处理的,但还是比用table简单明了, 于是又上网去找资料了, 找到资料.

以下摘录:

  1. 自动换行问题,正常字符的换行是比较合理的,而连续的数字和英文字符常常将容器撑大,挺让人头疼,下面介绍的是CSS如何实现换行的方法
  2.  
  3. 对于div,p等块级元素
  4. 正常文字的换行(亚洲文字和非亚洲文字)元素拥有默认的white-space:normal,当定义的宽度之后自动换行
  5. html
  6. <div id="wrap">正常文字的换行(亚洲文字和非亚洲文字)元素拥有默认的white-space:normal,当定义</div>
  7. css
  8. #wrap{white-space:normal; width:200px; }
  9.  
  10. 1.(IE浏览器)连续的英文字符和阿拉伯数字,使用word-wrap : break-word ;或者word-break:break-all;实现强制断行
  11.  
  12. #wrap{word-break:break-all; width:200px;}
  13. 或者
  14. #wrap{word-wrap:break-word; width:200px;}
  15.  
  16. <div id="wrap">abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div>
  17.  
  18. 效果:可以实现换行
  19.  
  20. 2.(Firefox浏览器)连续的英文字符和阿拉伯数字的断行,Firefox的所有版本的没有解决这个问题,我们只有让超出边界的字符隐藏或者,给容器添加滚动条
  21.  
  22. #wrap{word-break:break-all; width:200px; overflow:auto;}
  23.  
  24. <div id="wrap">abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div>
  25.  
  26. 效果:容器正常,内容隐藏
  27.  
  28. 对于table
  29.  
  30. 1. (IE浏览器)使用 table-layout:fixed;强制table的宽度,多余内容隐藏
  31.  
  32. <table style="table-layout:fixed" width="200">
  33. <tr>
  34. <td>abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss
  35. </td>
  36. </tr>
  37. </table>
  38.  
  39. 效果:隐藏多余内容
  40.  
  41. 2.(IE浏览器)使用 table-layout:fixed;强制table的宽度,内层td,th采用word-break : break-all;或者word-wrap : break-word ;换行
  42.  
  43. <table width="200" style="table-layout:fixed;">
  44. <tr>
  45. <td width="25%" style="word-break : break-all; ">abcdefghigklmnopqrstuvwxyz 1234567890
  46. </td>
  47. <td style="word-wrap : break-word ;">abcdefghigklmnopqrstuvwxyz 1234567890
  48. </td>
  49. </tr>
  50. </table>
  51.  
  52. 效果:可以换行
  53.  
  54. 3. (IE浏览器)在td,th中嵌套div,p等采用上面提到的div,p的换行方法
  55.  
  56. 4.(Firefox浏览器)使用 table-layout:fixed;强制table的宽度,内层td,th采用word-break : break-all;或者word-wrap : break-word ;换行,使用overflow:hidden;隐藏超出内容,这里overflow:auto;无法起作用
  57.  
  58. <table style="table-layout:fixed" width="200">
  59. <tr>
  60. <td width="25%" style="word-break : break-all; overflow:hidden; ">abcdefghigklmnopqrstuvwxyz1234567890</td>
  61. <td width="75%" style="word-wrap : break-word; overflow:hidden; ">abcdefghigklmnopqrstuvwxyz1234567890</td>
  62. </tr>
  63. </table>
  64.  
  65. 效果:隐藏多于内容
  66.  
  67. 5.(Firefox浏览器) 在td,th中嵌套div,p等采用上面提到的对付Firefox的方法
  68. 运行代码框
  69. 最后,这种现象出现的几率很小,但是不能排除网友的恶搞。
  70.  
  71. 下面是提到的例子的效果
  72.  
  73. < !DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  74. <html xmlns="http://www.w3.org/1999/xhtml">
  75. <head>
  76. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  77. <title>字符换行</title>
  78. <style type="text/css">
  79. table,td,th,div { border:1px green solid;}
  80. code { font-family:"Courier New", Courier, monospace;}
  81. </style>
  82. </head>
  83. <body>
  84. <h1><code>div</code></h1>
  85. <h1><code>All white-space:normal;</code></h1>
  86. <div style="white-space:normal; width:200px;">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>
  87.  
  88. <h1><code>IE \ word-wrap : break-word ;</code></h1>
  89. <div style="word-wrap : break-word ; width:200px;">abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div>
  90. <h1><code>IE \ word-break:break-all;</code></h1>
  91. <div style="word-break:break-all;width:200px;">abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div>
  92.  
  93. <h1><code>Firefox/ word-break:break-all; overflow:auto;</code></h1>
  94. <div style="word-break:break-all; width:200px; overflow:auto;">abcdefghijklmnabcdefghijklmnabcdefghijklmn111111111</div>
  95. <h1><code>table</code></h1>
  96. <h1><code>table-layout:fixed;</code></h1>
  97. <table style="table-layout:fixed" width="200">
  98. <tr>
  99. <td>abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss</td>
  100. </tr>
  101. </table>
  102. <h1><code>table-layout:fixed; word-break : break-all; word-wrap : break-word ;</code></h1>
  103. <table width="200" style="table-layout:fixed;">
  104. <tr>
  105. <td width="25%" style="word-break : break-all; ">abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss</td>
  106. <td style="word-wrap : break-word ;">abcdefghigklmnopqrstuvwxyz1234567890ssssssssssssss</td>
  107. </tr>
  108. </table>
  109. <h1><code>FF \ table-layout:fixed; overflow:hidden;</code></h1>
  110. <table style="table-layout:fixed" width="200">
  111. <tr>
  112. <td width="25%" style="word-break : break-all; overflow:hidden; ">abcdefghigklmnopqrstuvwxyz1234567890</td>
  113. <td width="75%" style="word-wrap : break-word; overflow:hidden; ">abcdefghigklmnopqrstuvwxyz1234567890</td>
  114. </tr>
  115. </table>
  116. </body>
  117. </html>

以上的是他人的例子,不过好有参考价值,初学CSS真的很多地方需要注意,好在这个年代可以上网查,还是蛮方便的,继续学习去……

关于无聊人

一个无聊人而已
此条目发表在CSS分类目录。将固定链接加入收藏夹。

发表评论

电子邮件地址不会被公开。 必填项已用*标注