zoukankan      html  css  js  c++  java
  • word-wrap ,word-break 和white-space 的联系

    在工作中我遇到一个问题,其实功能也不复杂,就是上面有个textarea标签 ,里面输入内容,下面有个显示效果 ,有个条件就是 上面输入的什么格式(比如换行等等),下面显示的也是 什么格式。如下图:

    这个功能真的不复杂。实现如下:

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Demo</title>
     6     <style>
     7         .reset{
     8             300px; margin: 20px auto 0; border:1px solid #00b3ee; height: auto;
     9             display: block;
    10         }
    11 12     </style>
    13 </head>
    14 <body>
    15 <textarea class="reset" id="inputText" rows="5"></textarea>
    16 <pre id="demoShow" class="reset">
    17 </pre>
    18 <script>
    19     (function(content){
    20         var oInputText=content.getElementById('inputText'),
    21                 oDemoShow=content.getElementById('demoShow');
    22         oInputText.onkeyup=function(){
    23             oDemoShow.innerHTML=oInputText.value;
    24         }
    25     })(document)
    26 </script>
    27 </body>
    28 </html>

    但是问题是当我 写的内容 如下时:

    内容竟然超出了,我不加思索的加上了:

    1  #demoShow{word-wrap: break-word; word-break: break-all;}

    结果,额,没反应;

    什么鬼,哦,我忘了white-space,看看他有什么值:

    对了,那就用pre-wrap或者pre-line ,那他们俩个具体是什么区别呢?

    pre-wrap是保留空白符序列,大白话就是 有多少空格就显示多少空格;

    pre-line 是合并空白符序列,大白话就是 无论多少空格只显示一个空格 和 对于首个单词前面的空格 不显示;

    所以咱的目的是保留用户输入的格式,那就要用pre-wrap;

    看看效果:

    太好了,成功了,可是这怎么回事?如下图:

    怎么单词断了,这是在产品中绝对不允许的,我该怎么办啊?我无数次的默念break-all....;突然 我灵光一闪,对了还有keep-all呢!我的上帝看看他们分别是什么 意思:

    哎呀就是 keep-all,就是keep-all ,看看效果如下:

    good,太美了,完整代码如下:

     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title>Demo</title>
     6     <style>
     7         .reset{
     8             300px; margin: 20px auto 0; border:1px solid #00b3ee; height: auto;
     9             display: block;
    10         }
    11         #demoShow{word-wrap: break-word; word-break: keep-all; white-space: pre-wrap;}
    12     </style>
    13 </head>
    14 <body>
    15 <textarea class="reset" id="inputText" rows="5"></textarea>
    16 <pre id="demoShow" class="reset">
    17 </pre>
    18 <script>
    19     (function(content){
    20         var oInputText=content.getElementById('inputText'),
    21                 oDemoShow=content.getElementById('demoShow');
    22         oInputText.onkeyup=function(){
    23             oDemoShow.innerHTML=oInputText.value;
    24         }
    25     })(document)
    26 </script>
    27 </body>
    28 </html>

    总结:

       说了这么多 ,其实我想说的是:word-wrap ,word-break 和white-space三个是相互扶助,共同完成一个 目标的。其中 :

       word-wrap是 确定是否换行,

       word-break是 确定换行是暴力换行,还是遇到空格 温柔的换行;

       white-space是 确定对于空格如何处理,对换行方式允许吗;

    谢谢大家批评指正!

  • 相关阅读:
    推荐一个很好得电子书下载网站
    C# 线程手册 第四章 线程设计原则 管道线程模型
    C# 线程手册 第六章 线程调试与跟踪
    C# 线程手册 第五章 扩展多线程应用程序 剖析ThreadPool 类
    C# 线程手册 第六章 线程调试与跟踪 代码跟踪
    C# 线程手册 第五章 多线程应用程序 .NET 中的扩展性
    C# 线程手册 第五章 扩展多线程应用程序 CLR 和 线程
    C# 线程手册 第五章 扩展多线程应用程序 什么是线程池
    C# 线程手册 第五章 多线程应用程序 一个多线程微软消息队列(MSMQ)监听器
    C# 线程手册 第六章 线程调试与跟踪 使用不同的监听器程序
  • 原文地址:https://www.cnblogs.com/zhangkunweb/p/6248044.html
Copyright © 2011-2022 走看看