对于CSS的white-space属性,我想大部分人应该和我差不多,最常用的就是nowrap属性,最多用来做超长省略号显示的时候会用到【hiahiahia~】

起因是这样的:产品doggie策划了一个元旦活动,活动主页最下边需要显示配置的活动规则,注意,是配置的活动规则,所以,免不了运营小妹要在后台配置一个活动规则,肯定不指望她们能配置html文本的呀,对吧,于是她们配置的是这样的:

    1、封垫苏菲房间都是克拉夫;2、对方萨芬的刷分放大;3、粉打发打发打发

这样色的,于是,取数据的时候,那隐藏的换行符免不了就被带走了走了了,它就变成了一个真正的,换行符。就像word文档里面看见的那样

于是,页面呈现与DOM结构就变成了这样

显然,这不是我们真实想要它呈现的效果,我们当然是想它能聪明的在该换行的时候换行呀,对吧,那么问题来了,为什么,它没有换行呢?

换行符

阿望脑袋里能记下来的换行符一共有4种

  1. \n:最初接触\n,是学C语言换行的时候,释义为:输入完一行内容后,光标转到下一行的起始位置
  2. \r\n:回车换行(回车:回车就是把水平位置复位,换行:换行就是往下一行,不改变水平位置,可以想象一下,在word文档中点击键盘回车键,其实执行的是回车+换行的操作)
  3. <br />:这个换行符是HTML唯一能识别的换行标签
  4. ↵:word文档软回车标记

当然,除了这几种,不同的语言可能会有它们自己的换行符,比如C++的endl,VB的空格+下划线

百度百科显示,word换行符是一种换行符号,它的作用是换行显示,但是它不是真正的段落标记,它的换行不是真正意义上的重起一段,因此被换行符分割的文字其实仍然还是一个段落中的,word中基于段落的所有操作都是不会识别换行符为段落结尾的,再加上在HTML中,只能识别br标签来做基本的文本换行,所以,这也就是文章开头说的,为什么word软回车换行符不能在HTML中正确回车显示了

HTML中的换行

在HTML中,换行可以有以下几种办法

块级元素包裹

这个就不多做解释了,块级元素最基本的定义就是一般都从新行开始,相邻的块级元素将会在不同行显示,默认了它的换行行为

br 标签

br 是HTML中默认的、唯一的可识别的换行元素,在要换行的地方加进去就行,它是一个自闭合标签

pre 标签

来,解释一下上面才说了br 是HTML中默认的、唯一的可识别的换行元素,怎么突然有冒了个pre标签出来!

pre 元素可定义预格式化的文本,被包围在 pre 元素中的文本通常会保留空格和换行符,而文本也会呈现为等宽字体,所以,并不是因为它被识别成了换行元素才导致换行,而是因为,它保留了文本节点最原始的格式,你给我什么,我还你什么,而不是像其他的元素,你给我充满换行符合空格的文本,我给你被我压缩压缩再压缩的瘦身版文本

友情提示:它不仅可以保留换行格式,还可以保留你的多个空格噢,因为pre元素默认带有样式 white-space: pre;

举个栗子

    <pre>1、封垫苏菲房间都     是克拉夫;2、对方萨芬的刷分放大;3、粉打发打发打发</pre>// 显示1、封垫苏菲房间都     是克拉夫;2、对方萨芬的刷分放大;3、粉打发打发打发<div>1、封垫苏菲房间都     是克拉夫;2、对方萨芬的刷分放大;3、粉打发打发打发</div>// 显示1、封垫苏菲房间都 是克拉夫; 2、对方萨芬的刷分放大; 3、粉打发打发打发

鉴于对pre标签的无知,在阿望还在做JSP的时候,遇到这种换行的需求通常都是正则表达式将换行符转换成br标签,然后通过HTML(vue的v-html)渲染成换行的DOM节点,相信也是大多数人的第一选择

    '我的字符串1\r\n\r\n\r\n\r\n我的字符串2\r\n111'.replace(/\r\n/g, '<br />')

现在想来,当初那些前辈们教下来的也是这个办法,估计,他们也没想到,一行CSS代码就能解决吧。。。

CSS属性换行

我们假设有个超长的文本节点:"哈哈哈,congratulations",我们假设有个容器长度只能装得下"哈哈哈,con"

word-break

word-break 属性规定自动换行的处理方法,可以让浏览器实现在任意位置的换行,它是CSS3推出的新属性(有兼容性问题),用来标明怎么样进行单词内的断句

什么叫单词内的断句呢?简单点来说,就是当文本节点"哈哈哈,congratulations"在容器中显示成了"哈哈哈,con[假设这里换了行]gratulations"的时候,就产生了单词内断句。浏览器默认的时候,"哈哈哈,congratulations"在容器中会显示成"哈哈哈,[假设这里换了行]congratulations",即:如果有一个单词很长,导致一行中剩下的空间已经放不下它时,则浏览器会把这个单词挪到下一行去

word-break一共有三个属性值

normal 浏览器默认的换行规则

"哈哈哈,congratulations"在容器中会显示成"哈哈哈,[假设这里换了行]congratulations"

break-all 允许在单词内换行(单词是指non-CJK (CJK 指中文/日文/韩文) 文本)

"哈哈哈,congratulations"在容器中会显示成"哈哈哈,con[假设这里换了行]gratulations"

keep-all 只能在半角空格或连字符处换行

CJK 文本不断行, Non-CJK 文本表现同 normal

word-wrap

word-wrap 属性允许长单词或 URL 地址换行到下一行

word-break一共有两个属性值

normal 只在允许的断字点换行(浏览器保持默认处理)

break-word 在长单词或 URL 地址内部进行换行

那么它与word-break的区别是什么呢?

首先看我们的前提条件:有个超长的文本节点:"哈哈哈,congratulations",我们假设有个容器长度只能装得下"哈哈哈,con",那么意味着,不添加word-break与word-wrap属性的时候,该文本节点在容器内显示为"哈哈哈,[假设这里换了行]congratulations",且单词congratulations肯定是冲出了容器边界的,超级难看。这个时候word-wrap就能派上用场了,给这段文字加上word-wrap: break-word之后,文本节点就会显示成"哈哈哈,[假设这里换了行]congratula[假设这里换了行]tions",这样,为了防止长单词溢出,就在它的内部断句了

那既然有word-wrap,又为什么要有word-break属性呢?简单来说,当设置word-break:break-all; word-wrap:break-word,我们的超长文本"哈哈哈,congratulations"就会显示成"哈哈哈,con[假设这里换了行]gratulatio[假设这里换了行]ns",它的用处就是:节省空间!是的,你没有看错!

word-wrap 是用来决定允不允许单词内断句的,如果不允许的话长单词就会溢出。最重要的一点是它还是会首先尝试挪到下一行,看看下一行的宽度够不够,不够的话就进行单词内的断句

word-break:break-all则更粗暴,直接进行单词内的断句

white-space

white-space 属性设置如何处理元素内的空白,这个属性声明建立布局过程中如何处理元素中的空白符,实际上会对列表溢出换行和文字溢出进行处理

空白符

空白符是指在屏幕不会显示出来的字符(如空格,制表符tab,回车换行等),HTML默认已经把所有空白符合并成一个空格

white-space一共有五个属性值

normal 默认,空白符会被浏览器忽略

多个空格合并成1个空格,换行符被忽略,在容器宽度内自调整换行

pre 空白会被浏览器保留,其行为方式类似 HTML 中的 pre 标签

多个空格被保留,换行符被保留,不会在容器宽度内自调整换行,直到遇到 br 标签为止

nowrap 文本不会换行,文本会在在同一行上继续,直到遇到 br 标签为止

多个空格合并成1个空格,换行符被忽略,不会在容器宽度内自调整换行,这是它与默认行为不一样的地方

pre-wrap 保留空白符序列,但是正常地进行换行

多个空格被保留,换行符被保留,在容器宽度内自调整换行

pre-line 合并空白符序列,但是保留换行符

多个空格合并成1个空格,换行符被保留,在容器宽度内自调整换行

inherit 规定应该从父元素继承 white-space 属性的值

以上,可根据实际情况选择自己想要的属性值

另:若换行处想添加连字符,将congratulations换行显示为con-gratulatio-ns的话,可使用属性hyphens:auto;在适当的位置自动插入连字符换行

关于换行以及换行属性相关推荐

  1. CSS Table不换行与换行的用法

    我们知道Div的换行和不换行的css写法.但对于表格单元格只知道一个属性nowrap可以使其不换行.近日有此需要,但发现加上nowrap在某些情况下还是会换行!无奈,没有一个强制不换行的方法吗? 用C ...

  2. DatagridView内容自动换行和换行符换行

    内容自动换行: 在 DataGridView 新增 Row 时,設定 DataGridView 的 DefaultCellStyle 屬性WrapMode=true: 换行符换行: 在 DataGri ...

  3. php去除换行(回车换行)的方法

    php去除换行(回车换行)的方法 php去除换行(回车换行)的三种方法. 代码: <?php      // php 不同系统的换行   //不同系统之间换行的实现是不一样的   //linux ...

  4. AngularJS 如何进行字符串换行 HTML 换行的互换

    AngularJS 字符串换行 & HTML 换行互换的一个解决方案 前言 如何实现字符串与 HTML 的平滑切换 效果图 结语 前言 在使用 textarea 标签设计多行输入功能时,我需要 ...

  5. 解决 HTML div css 强制 换行 不换行

    1.强制不换行,同时以省略号结尾. <div style="width:100px;overflow:hidden;white-space:nowrap;text-overflow:e ...

  6. css 第二行换行,CSS换行详解

    普通文本段落的换行 案例说明:在实际应用中我们常遇到这样的问题,就是一段文本,有了明确的宽度,需要文本自动换行.(如下图) 案例分析:上面两个图,没有使用任何排版的CSS属性,也就是默认情况下,块元素 ...

  7. TextBox换行C#文本框换行.net文本框换行textarea换行

    在TextBox中输入的内容,显示的时候如果用lable显示,无法换行 可以使用TextBox输入,然后也使用TextBox 显示,这样换行输入的内容,显示的时候也可以换行.显示的时候可以设置一下控件 ...

  8. html怎么换行?换行代码是什么?九种html文字换行方法总结

    在用html写网页时,为了让网页中内容看起来整洁流畅,我们需要将其中的文字内容进行换行,那么,html怎么来换行呢?本篇文章就来给大家介绍一下html中给文字换行的方法. 打造全网web前端全栈资料库 ...

  9. html怎么批量换行,html怎么换行?换行代码是什么?九种html文字换行方法总结

    在用html写网页时,为了让网页中内容看起来整洁流畅,我们需要将其中的文字内容进行换行,那么,html怎么来换行呢?本篇文章就来给大家介绍一下html中给文字换行的方法. html中换行的方法有很多, ...

最新文章

  1. OKR简单通俗易懂的介绍,1分钟了解什么是OKR工作法
  2. 国内人脸识别第一案,我们来谈谈国外法规和隐私保护技术
  3. Asp.net2.0下的大文件上传服务器控件
  4. 一个IO的传奇一生(8) -- elevator子系统
  5. OpenCV-Python教程(9)(10)(11): 使用霍夫变换检测直线 直方图均衡化 轮廓检测
  6. 字符串反转python_Python 反转字符串(reverse)的方法小结
  7. 关于考研一些问题的思考2017-12-23
  8. 过程记录 yolov3目标检测输出目标坐标和原图物体像素坐标比较
  9. POJ 1745 Divisibility【DP】
  10. 轻松学DIV教程(div+css布局)
  11. SVG 教程 (一)
  12. php urledcode_用JavaScript实现PHP的urldecode函数
  13. Windows 10 安装SVN 不显示状态图标--解决方法
  14. python工资一般多少-Python就业都有哪些岗位?每个岗位薪资多少?
  15. 蓝桥杯 字母组串(递归)
  16. Vs自带的freetextbox无法在远端使用
  17. js把txt转为html,js格式化文本为html标签
  18. 35岁 计算机 学 什么好,35岁一事无成, 想重新学习, 应该学习哪方面的技能?
  19. 《现代密码学教程》| 谷利泽 | 课后答案 | 个人整理
  20. 7-3 干支纪年法 (100 分)

热门文章

  1. Git Tower 3.2 - 最好用的代码管理工具
  2. 我为什么鼓励你读博士?
  3. Apollo 6.0 Mid2Mid Planner论文阅读
  4. 【Python】5行代码缩小图片尺寸
  5. Java实现微信运动步数(已自测)
  6. leetcode 第1题【两数之和】C语言
  7. /和./和../的区别
  8. 用上柔宇「办公神器套装」,我一天就写了三天的稿子
  9. 爆款升级!新系列南卡Neo最强旗舰杀到,业内首款无线充骨传导耳机!
  10. [20171122]rman filesystemio_options.txt