CSS – word-break, overflow-wrap, word-wrap, white-space
参考
word-break 和 word-wrap 的区别 (我以为这篇已经很厉害了)
彻底搞懂word-break、word-wrap、white-space (没想到, 这一篇更厉害)
white-space
white-space 是负责管理空格, 换行的, 比如 <br>, \n
默认的行为:
和 <br> 有效
连续的 space 会被缩减成一个
\n 无效
句子超过一行后会自动换行
单个字太长则会超出边界.
大神已经整理很好给我们了:

一般而言, 不需要背起来, 只需要知道默认行为和最常遇到的情况就可以了.
\n 无效是最常遇到的问题. 比如 user 通过 textarea 写了 \n 换行, 后来被弄掉了.
解决方案就是用 white-space: pre-line
word-break
word-break 讲的是单个字要怎样 break.
默认情况, 英文就是看连续字母一直到空格算一个能被 break 的字. 中文不看空格, 每一个字都可以被 break
break-all
break-all 的情况, 英文的每一个字母都可以被 break. 中文本来就可以.
keep-all
keep-all 的情况, 中文变得跟英文一样, 只有到空格才能被 break.
2 个都很少会被用到. 因为效果都不太好.
overflow-wrap (word-wrap)
以前叫 word-wrap. CSS 3 后改的, 现在都支持了。
break-word
它的效果就是只有当一个字没办法被 break 又超过了边界时, 才把那个字 break-all. 这才是最常用到的体验.
当遇到 flex, break-word 失效
参考: Stack Overflow – flex item overflows container due to long word even after using word-wrap

其原因是 flex item 在没有设置 min width 的时候, 最小就是 width 本身. 当设置 min-width: 0 以后, 就会看到 break-word 效果了.
但这招感觉有点 hacking 的味道...
还有一招是用
word-break: break-word;
不过这招当遇到很长很长的字, 它也会 break 掉. 这个体验不一定是想要的.
总结
几个东西需要记住
1. 连续 space 会被合并, 所以要连续 space 就得用
2. 默认 \n 是无效的, 需要加 white-space: pre-line
3. 当遇到 1 个很长的单字时, 用 overflow-wrap: break-word 把它 break 掉
4. 如果不希望自动换行 white-space: nowrap; 或者 pre; 区别是 pre 允许 \n
题外话: 当 inline element 遇上 new line
<p><span>abc</span><span>xyz</span><span>123</span></p>
<p>
<span>abc</span>
<span>xyz</span>
<span>123</span>
</p>
这 2 个 <p> 渲染出来的效果是不一样的

第一个 <p> 间中没有空格
第二个 <p> 中间却有空格, 所以当 inline element 遇上 new line 会变成空格哦. 这个要注意了.
CSS – word-break, overflow-wrap, word-wrap, white-space的更多相关文章
- leetcode 139. Word Break 、140. Word Break II
139. Word Break 字符串能否通过划分成词典中的一个或多个单词. 使用动态规划,dp[i]表示当前以第i个位置(在字符串中实际上是i-1)结尾的字符串能否划分成词典中的单词. j表示的是以 ...
- 139. Word Break 以及 140.Word Break II
139. Word Break Given a non-empty string s and a dictionary wordDict containing a list of non-empty ...
- word break和word wrap
默认情况下,如果同一行中某个单词太长了,它就会被默认移动到下一行去: word break(normal | break-all | keep-all):表示断词的方式 word wrap(norma ...
- [LeetCode] Word Break II 拆分词句之二
Given a string s and a dictionary of words dict, add spaces in s to construct a sentence where each ...
- 【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 ...
- 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 ...
- LeetCode:Word Break II(DP)
题目地址:请戳我 这一题在leetcode前面一道题word break 的基础上用数组保存前驱路径,然后在前驱路径上用DFS可以构造所有解.但是要注意的是动态规划中要去掉前一道题的一些约束条件(具体 ...
- LeetCode Word Break II
原题链接在这里:https://leetcode.com/problems/word-break-ii/ 题目: Given a string s and a dictionary of words ...
- 【LeetCode OJ】Word Break II
Problem link: http://oj.leetcode.com/problems/word-break-ii/ This problem is some extension of the w ...
- Leetcode#139 Word Break
原题地址 与Word Break II(参见这篇文章)相比,只需要判断是否可行,不需要构造解,简单一些. 依然是动态规划. 代码: bool wordBreak(string s, unordered ...
随机推荐
- API是什么
API就是接口,就是通道,负责一个程序和其他软件的沟通,本质是预先定义的函数.譬如我们去办事,窗口就类似一个API,如果对于某一件不简单的事情,这个窗口能做到让我们"最多跑一次", ...
- git将本地代码提交到远程仓库
来源:https://blog.csdn.net/gaoying_blogs/article/details/53337112 将本地代码上传到远程仓库的时候,打开命令行窗口,进入到本地代码的文件夹. ...
- Memcache 与 Memcached 的区别
Memcached 从0.2.0开始,要求PHP版本>=5.2.0,Memcache 要求PHP版本>=4.3. Memcached 最后发布时间为2018-12-24,Memcache ...
- [oeasy]python0117 文字的演化_埃及圣书体_象形文字_楔形文字
埃及圣书体 回忆上次内容 两河流域 苏美尔文明 所使用的 楔形文字 不是象形文字 添加图片注释,不超过 140 字(可选) 楔形文字的字型 究竟是怎么来的呢? 巴别塔 苏美尔的 ...
- 深入理解 Vue 3 组件通信
在 Vue 3 中,组件通信是一个关键的概念,它允许我们在组件之间传递数据和事件.本文将介绍几种常见的 Vue 3 组件通信方法,包括 props.emits.provide 和 inject.事件总 ...
- Docker 容器数据:持久化
Docker 容器数据:持久化 每当从镜像创建容器时,它都会创建一个新容器,除了镜像数据之外没有任何数据 意味着如果在提交更改之前删除容器,我们将丢失数据 Docker 应该存在一种将数据的文件系统与 ...
- python virtualenv虚拟环境配置与使用
python virtualenv虚拟环境配置与使用 By:赖富玉 QQ:1033553122 概述 python开发过程中,我们可能需要同时开发多款应用,这些应用可能公用同一个版本的Python程序 ...
- 缓存框架 Caffeine 的可视化探索与实践
作者:vivo 互联网服务器团队- Wang Zhi Caffeine 作为一个高性能的缓存框架而被大量使用.本文基于Caffeine已有的基础进行定制化开发实现可视化功能. 一.背景 Caffei ...
- ubuntu禁止内核自动更新
ubuntu禁止内核自动更新 查看已安装内核dpkg --get-selections |grep linux-image 查看正在使用的内核uname -a 禁止内核更新sudo apt-mark ...
- 前端使用 Konva 实现可视化设计器(19)- 连接线 - 直线、折线
本章响应小伙伴的反馈,除了算法自动画连接线(仍需优化完善),实现了可以手动绘制直线.折线连接线功能. 请大家动动小手,给我一个免费的 Star 吧~ 大家如果发现了 Bug,欢迎来提 Issue 哟~ ...