继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

CSS 文本控制

1步
关注TA
已关注
手记 24
粉丝 120
获赞 651

one more time one more chance. 一歩重头学前端, css入门。

学习一些 CSS 文本控制的属性,防止做傻事。请大家对照下面列表检验下: 会的、不会的、似懂非懂的。笔者是一个也不会。

  1. white-space
  2. text-overflow: ellipsis;
  3. word-break, word-wrap
  4. text-align: justify
  5. text-decoration
  6. text-transform
  7. text-indent
  8. letter-spacing
  9. word-spacing
文本溢出显示(...)
.truncate {
    white-space: nowrap;
    text-overflow: ellipsis;
    overflow: hidden;
}

这个简单的 css语句,使用的比较多了吧,那么请解释下 white-space 和 text-overflow,我尼玛,并不会是不是。
图片描述

white-space

white-space用来设置内容中的空格的处理方式。

white-space:normal | pre | nowrap | pre-wrap | pre-line

white-space: nowrap不换行,空格会被合并: 1. 第一行开始我写了好多空格在实际效果中被合并成了一个;2. 然后中间又键入了回车,但是前端并未换行; 3. <br />是可以使文本换行的;

white-space: pre保留空格(包括键入的回车换行),单行文本过长时不会自动换行, <br />在任何情况下都是可以生效的。
See the Pen

pre-wrap是pre 的升级版,当单行文本过长,超过文本边界时自动换行。请自行演示代码。pre-line作为自学内容。

text-overflow

用来定义当文本超出容器边界时如何处理。

/*切断 | 使用省略号 | 使用自定义的字符串*/
text-overflow: clip|ellipsis|string;

看个极端点的例子: 给 div 宽度限定为 width:500px,然后 overflow: hidden 确定该 div 的 文本边界,不能再多了,再然后 white-space: pre 保留空格,但是当文本超出边界时不会自动换行,这样每行文本就都超出了边界,此时我们再尝试使用 text-overflow 进行溢出限制。

See the Pen

那么现在就可以解释单行文本溢出时加三个点显示的代码了:

white-space: nowrap; /*容器内的文本单行显示*/
overflow: hidden; /*确定文本边界,容器的边界就是文本的界限不可以突出去*/
text-overflow: ellipsis; /*超出的部分使用3个点代替*/

不要忘记思考: 多行文本溢出,省略显示如何实现。

word-break, word-wrap

推荐大家阅读你真的了解word-wrap和word-break的区别吗
word-wrap 和 word-break 问答
断字规则
每种语言都有各自的默认断字规则,在哪个位置可以插入break-points(断点),当需要换行显示时,会根据这些断点来决定从文字的哪个位置开始换行。 比如汉字你好吗的断点你·好·吗,中间的点表示断点的位置; 比如英文hello world的断点hello·world;

那么,我们可能想要改变这些默认的断点规则,word-break属性就是做这个的,它会改变默认的断点规则。当设置word-break: break-all;的时候,上面的汉字断点规则并没有改变,英文的断点除了默认的空白符和符号断点外,还会在任意两个字母之间添加断点,也就是说任意位置是可以断开的,此时英文hello world的断点也就变为h·e·l·l·o·w·o·r·l·d;

文字排版会按照断字规则(浏览器规则或自定义规则)进行排版,如果一个很长很长的单词中间又是不可断的时候word-wrap就可以上场了,word-wrap 是用来决定允不允许单词内断句的,如果不允许的话长单词就会溢出。word-wrap: break-word它会首先尝试将整个长单词挪到下一行,看看下一行的宽度够不够,不够的话还会进行单词内的断句。

word-break: normal|break-all|keep-all;word-break的本质是更改断点规则, normal 正常规则,break-all 到处都可以断,keep-all只能在半角空格或连字符处换行(试试长中文的句子就明白了)。

See The Pen

word-wrap: normal|break-word;normal,只在允许的断字点换行基于浏览器默认设置或者 word-break 的设置。break-word它会首先尝试将整个长单词挪到下一行,看看下一行的宽度够不够,不够的话就进行单词内的断句。

综上,我自己明白了,可能大家已经被我绕晕了。

图片描述

white-space word-wrap word-break 三者的关系

white-space、word-wrap、word-break 是不太好理解。没解释明白的话,请跳转连接看看大牛们的文章。

若设置了 white-space 后,word-wrap 和 word-break又如何表现呢? 请记住white-space 老大,word-break 老二,word-wrap 第三。如果设置了 white-space: nowrap,后两者是不起作用的。

See the Pen

text-align: justify 两端对齐

是不是都用过 text-align: left | right;那么 justify 是干什么的呢?下图是个常见的需求文字两端对齐。

图片描述

笔者曾经使用 来打空格,真是 SB 啊,用这么 low 的方法明显反应出我既不会 text-align 也不会 white-space。

css的两端对齐有个,最后一行的文字不会两端对齐,而是左对齐。
推荐大家看看大漠的解释: 在其自然状态下,"text-align:justify"就不能工作,除非内容足够长并引起一个换行符。否则,文本仍然左对齐。如果你想知道这是为什么,这是因为在排版中这是理想的行为——一个块中的最后一行文本总是左对齐。也许这是一个CSS规范设计,即使我们只有一行文本,这一行还是像最后一行一样,让文本左对齐。

如何保证两端对齐呢? 人为插入一行东西,使得文本处于倒数第二行。

See The Pen

text-decoration

文字装饰text-decoration : none | underline | blink | overline | line-through
在修饰 a 标签时用的较多用于去除下划线。

a {
    text-decoration: none;
}
text-transform

text-transform 属性控制文本的大小写。学会了该属性,我们再也不用使用 js 来切换大小写了。
text-transform: none | capitalize | uppercase | lowercase

See The Pen

text-indent

控制首行缩进,有了它也不用 了,简单好用。

p {
  text-indent:50px;
}
letter-spacing word-space

letter-spacing和word-spacing这两个属性都用来控制元素中的空白宽度的。letter-spacing添加字母之间的空白,而word-spacing添加每个单词之间的空白。请大家注意,word-spacing对中文无效。

See The Pen

引用

你真的了解word-wrap和word-break的区别吗
word-wrap 和 word-break 问答
断字规则
Text-align:Justify和RWD
text-align:justify两端对齐有个坑

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP