本文列举了兼容 IE 和 FF 的换行 CSS 推荐样式,详细介绍了word-wrapword-break的区别。 
  兼容 IE 和 FF 的换行 CSS 推荐样式

最好的方式是

以下是引用片段:
  word-wrap:break-word; overflow:hidden;

  而不是

以下是引用片段:
  word-wrap:break-word; word-break:break-all;

  也不是

以下是引用片段:
  word-wrap:break-word; overflow:auto;

  在 IE 下没有任何问题,在 FF 下,长串英文会被遮住超出的内容。

  word-wrap同word-break的区别

  word-wrap:

  normal  Default. Content exceeds the boundaries of its container.

  break-word Content wraps to next line, and a word-break occurs when necessary. 必要时会触发word-break。

  word-break:

  normal  Default. Allows line breaking within words. 好像是只对Asian text起作用。

  break-all Behaves the same as normal for Asian text, yet allows the line to break arbitrarily for non-Asian text. This value is suited to Asian text that contains some excerpts of non-Asian text.

  keep-all Does not allow word breaking for Chinese, Japanese, and Korean. Functions the same way as normal for all non-Asian languages. This value is optimized for text that includes small amounts of Chinese, Japanese, or Korean.

  总结如下:

  word-wrap是控制换行的。

  使用break-word时,是将强制换行。中文没有任何问题,英文语句也没问题。但是对于长串的英文,就不起作用。

  break-word是控制是否断词的。

  normal是默认情况,英文单词不被拆开。

  break-all,是断开单词。在单词到边界时,下个字母自动到下一行。主要解决了长串英文的问题。

  keep-all,是指Chinese, Japanese, and Korean不断词。即只用此时,不用word-wrap,中文就不会换行了。(英文语句正常。)

  ie下:

  使用word-wrap:break-word;所有的都正常。

  ff下:

  如这2个都不用的话,中文不会出任何问题。英文语句也不会出问题。但是,长串英文会出问题。

  为了解决长串英文,一般用word-wrap:break-word;word-break:break-all;。但是,此方式会导致,普通的英文语句中的单词会被断开(ie下也是)。

  目前主要的问题存在于 长串英文 和 英文单词被断开。其实长串英文就是一个比较长的单词而已。

  即英文单词应不应该被断开那?那问题很明显了,显然不应该被断开了。

  对于长串英文,就是恶意的东西,自然不用去管了。但是,也要想些办法,不让它把容器撑大。

  用:overflow:auto; ie下,长串会自动折行。ff下,长串会被遮盖。

  所以,综上,最好的方式是word-wrap:break-word;overflow:hidden;而不是word-wrap:break-word;word-break:break-all;。

  word-wrap:break-word;overflow:auto;在ie下没有任何问题。在ff下,长串会被遮住部分内容。

  另,测试代码如下:

  1.htm

  <style>

  .c1{ width:300px;  border:1px solid red}

  .c2{ width:300px;word-wrap:break-word;  border:1px solid yellow}

  .c3{ width:300px;word-wrap:break-word;word-break:break-all;  border:1px solid green}

  .c4{ width:300px;word-wrap:break-word;word-break:keep-all; border:1px solid blue}

  .c5{ width:300px;word-break:break-all;  border:1px solid black}

  .c6{ width:300px;word-break:keep-all;  border:1px solid red}

  .c7{ width:300px;word-wrap:break-word;overflow:auto;  border:1px solid yellow}

  </style>

  .c1{ width:300px;  border:1px solid red}

  <div class="c1">asdasd

</div>

  <div class="c1">

  This is all English. This is all English. This is all English.

  </div>

  <div class="c1">

  全是中文的情况。全是中文的情况。全是中文的情况。

  </div>

  <div class="c1">

  中英文混排的情况。Chinese and English. 中英文混排的情况。Chinese and English.

  </div>

  <br>

  .c2{ width:300px;word-wrap:break-word; border:1px solid yellow}

  <div class="c2">

  safjaskflasjfklsajfklasjflksajflksjflkasjfksafj

  </div>

  <div class="c2">

  This is all English. This is all English. This is all English.

  </div>

  <div class="c2">

  全是中文的情况。全是中文的情况。全是中文的情况。

  </div>

  <div class="c2">

  中英文混排的情况。Chinese and English. 中英文混排的情况。Chinese and English.

  </div>

  <br>

  .c3{ width:300px;word-wrap:break-word;word-break:break-all;  border:1px solid green}

  <div class="c3">

  safjaskflasjfklsajfklasjflksajflksjflkasjfksafj

  </div>

  <div class="c3">

  This is all English. This is all English. This is all English.

  </div>

  <div class="c3">

  全是中文的情况。全是中文的情况。全是中文的情况。

  </div>

  <div class="c3">

  中英文混排的情况。Chinese and English. 中英文混排的情况。Chinese and English.

  </div>

  <br>

  .c4{ width:300px;word-wrap:break-word;word-break:keep-all; border:1px solid blue}

  <div class="c4">

  safjaskflasjfklsajfklasjflksajflksjflkasjfksafj

  </div>

  <div class="c4">

  This is all English. This is all English. This is all English.

  </div>

  <div class="c4">

  全是中文的情况。全是中文的情况。全是中文的情况。

  </div>

  <div class="c4">

  中英文混排的情况。Chinese and English. 中英文混排的情况。Chinese and English.

  </div>

  <br>

  .c5{ width:300px;word-break:break-all;  border:1px solid black}

  <div class="c5">

  safjaskflasjfklsajfklasjflksajflksjflkasjfksafj

  </div>

  <div class="c5">

  This is all English. This is all English. This is all English.

  </div>

  <div class="c5">

  全是中文的情况。全是中文的情况。全是中文的情况。

  </div>

  <div class="c5">

  中英文混排的情况。Chinese and English. 中英文混排的情况。Chinese and English.

  </div>

  <br>

  .c6{ width:300px;word-break:keep-all;  border:1px solid red}

  <div class="c6">

  safjaskflasjfklsajfklasjflksajflksjflkasjfksafj

  </div>

  <div class="c6">

  This is all English. This is all English. This is all English.

  </div>

  <div class="c6">

  全是中文的情况。全是中文的情况。全是中文的情况。

  </div>

  <div class="c6">

  中英文混排的情况。Chinese and English. 中英文混排的情况。Chinese and English.

  </div>

  <br>

  .c7{ width:300px;word-wrap:break-word;overflow:auto;  border:1px solid yellow}

  <div class="c7">

  safjaskflasjfklsajfklasjflksajflksjflkasjfksafj

  </div>

  <div class="c7">

  This is all English. This is all English. This is all English.

  </div>

  <div class="c7">

  全是中文的情况。全是中文的情况。全是中文的情况。

  </div>

  <div class="c7">

  中英文混排的情况。Chinese and English. 中英文混排的情况。Chinese and English.

  </div>

word-break与word-wrap的更多相关文章

  1. word break和word wrap

    默认情况下,如果同一行中某个单词太长了,它就会被默认移动到下一行去: word break(normal | break-all | keep-all):表示断词的方式 word wrap(norma ...

  2. [LeetCode] Word Break II 拆分词句之二

    Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each ...

  3. 【leetcode】Word Break II

    Word Break II Given a string s and a dictionary of words dict, add spaces in s to construct a senten ...

  4. 17. Word Break && Word Break II

    Word Break Given a string s and a dictionary of words dict, determine if s can be segmented into a s ...

  5. LeetCode:Word Break II(DP)

    题目地址:请戳我 这一题在leetcode前面一道题word break 的基础上用数组保存前驱路径,然后在前驱路径上用DFS可以构造所有解.但是要注意的是动态规划中要去掉前一道题的一些约束条件(具体 ...

  6. LeetCode Word Break II

    原题链接在这里:https://leetcode.com/problems/word-break-ii/ 题目: Given a string s and a dictionary of words  ...

  7. 【LeetCode OJ】Word Break II

    Problem link: http://oj.leetcode.com/problems/word-break-ii/ This problem is some extension of the w ...

  8. Leetcode#139 Word Break

    原题地址 与Word Break II(参见这篇文章)相比,只需要判断是否可行,不需要构造解,简单一些. 依然是动态规划. 代码: bool wordBreak(string s, unordered ...

  9. 【leetcode】Word Break (middle)

    Given a string s and a dictionary of words dict, determine if s can be segmented into a space-separa ...

  10. 140. Word Break II

    题目: Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where e ...

随机推荐

  1. HTTP 错误 401.3 - Unauthorized由于 Web 服务器上此资源的访问控制列表(ACL)解决办法

    对应站点目录的IUSR的权限没设造成的...在属性——>安全——> 高级 中把IUSR用户找出来添加好就OK了 注:IUSR(匿名访问 Internet 信息服务的内置帐户)

  2. 2)PHP中把读取.txt中内容并转为UTF-8格式

    <?php $filename = "filename.txt"; $handle = fopen($filename, "r");//读取二进制文件时, ...

  3. ubuntu-10.04的测试环境 安装测试 Coreseek开源中文检索引擎-Sphinx中文版

    主要参考文档:http://www.coreseek.cn/products-install/install_on_bsd_linux/ 一. 32位版本: coreseek安装需要预装的软件: ap ...

  4. 解决 winedit 打开tex文件 reading error

    从网上下载的论文模板,发现直接双击打开.tex文件(默认关联用winedit打开)时会出现reading error,然后看不到任何文字(网上有人讨论打开是乱码的问题,但是我的是完全看不到任何东西), ...

  5. JS笔记 入门第四

    小测试: 注意:取消所有的设定可以直接使用 document.getElementById("txt").removeAttribute("style"); 这 ...

  6. 四轴飞行器1.2.3 STM32F407时钟配置和升级标准库文件

    原创文章,欢迎转载,转载请注明出处 这个星期进度比较慢哈,只有周末和晚上下班回来才能做,事件不连续,琐碎的事情又比较多,挺烦的,有多琐碎呢?           1.本人有点小强迫症哈,虽然RTT将文 ...

  7. 《Pointers On C》读书笔记(第四章 语句)

    1.空语句只包含一个分号,它本身并不执行任何任务,其适用的场合是语法要求出现一条完整的语句,但并不需要它执行任何任务. 2.C语言中并不存在专门的“赋值语句”,赋值就是一种操作,在表达式内进行.通过在 ...

  8. Linux 关机

    1. shutdown shutdown -h now 立刻关机 shutdown -h 22:50 22:50 分的时候关机 shutdown -h +10 10分钟后关机 shutdwon -r ...

  9. JAVA并发,CountDownLatch使用

    该文章转自:http://www.itzhai.com/the-introduction-and-use-of-a-countdownlatch.html CountDownLatch 1.类介绍 一 ...

  10. Qt双缓冲机制:实现一个简单的绘图工具(纯代码实现)

    http://blog.csdn.net/rl529014/article/details/51658350