资讯专栏INFORMATION COLUMN

css文本换行总结

Caizhenhao / 2726人阅读

摘要:到文本过长的问题,元素的宽度不足以容那文本的内容,文本超出元素显示,遇到这种情况,一般有两种处理方式,一种是超出省略不显示,很暴力,很直接,还有一种就是换行显示,下面我将会介绍几种种常用的换行方法。但文本内的换行无效。

到文本过长的问题,元素的宽度不足以容那文本的内容,文本超出元素显示,遇到这种情况,一般有两种处理方式,一种是超出省略不显示,很暴力,很直接,还有一种就是换行显示,下面我将会介绍几种css种常用的换行方法。

word-break

相信这个属性大家都不陌生,在介绍这个属性之前先介绍一个缩写CJK:中日韩统一表意文字,在下面的介绍中将会用到这个名词,让我们先来简单介绍一下word-break的几个属性:

normal:使用默认断行规则

break-all:对于非CJK文本,可在任意字符间断行

keep-all:CJK文本不断行,非CJK文本表现同normal一样

下面我们来看几个例子:

abashdgsgdjagdjasddnsadvadfjasdgagdagsjdgasgdajsghsa
测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试测试
test test Strawberry test test test test test test test test
div {
  width: 100px;
  word-break: normal;
}

当word-break为normal时,即使用默认规则时可以看到CJK文本会自动行,非CJK文本不会自动换行,会超出容器,但是在查找到空格这类可以作为换行依据的内容时,非CJK内容也能实现换行

div {
  width: 100px;
  word-break: break-all;
}

从上面可以看到:break-all属性很霸道,只要容器装不下了,就会立即换行,不管是CJK内容还是非CJK内容,也可以理解为break-all将非CJK内容作为CJK处理

div {
  width: 100px;
  word-break: keep-all;
}

从上面可以看到:keep-all属性恰好和break-all相反,将CJK内容当成非CJK内容处理

overflow-wrap

有可能有人看到这个属性有点陌生,但是我一说word-wrap大家一定不陌生,其实它就是word-wrap换了个名字而已,属性值一摸一样,下面就来介绍一下它的属性值:

normal:表示在正常的单词结束处换行

break-word:表示如果行内没有多余的地方容纳该单词到结尾,则那些正常的不能被分割的单词会被强制分割换行

让我们来看个例子:

div {
  width: 100px;
  overflow-wrap: break-word;
}

从上面例子可以看到:当属性值为break-word时,当到达容器边界时,如果单词还没有结束,也会自动换行,如果找到空格明确单词结束时,就会判断当前行剩余宽度是否还能容纳下一个单词,如果不行就会执行换行,以避免单词溢出

white-space

这个属性在文本超出显示省略号的时候大家一定用过,下面就来看一下这个属性的属性值:

normal:连续的空白符会被合并,换行符会被当作空白符处理。填充line盒子时,必要的话会换行。

nowrap:和normal一样,连续的空白符会被合并。但文本内的换行无效。

pre:连续的空白符会被保留。在遇到换行符或者
元素时才会换行。

pre-wrap:连续的空白符会被保留。在遇到换行符或者
元素,或者需要为了填充line盒子时才会换行。

pre-line:连续的空白符会被合并。在遇到换行符或者
元素,或者需要为了填充line盒子时会换行。

来看几个具体的例子表现:

test test test test test test test test test test test
div {
  width: 100px;
  white-space: normal;
}

上面例子中,为了看出是否会合并空白符,特意在div前面加了两个空格。可以看到值为normal时,会合并连续空白符,并且会换行符作为空白符处理

div {
  width: 100px;
  white-space: nowrap;
}

nowrap属性就和大家常见的一样文本内换行无效,但是会合并连续空白符

div {
  width: 100px;
  white-space: pre;
}

pre值可以看到,会保留连续空白符,且只有在遇到换行符的时候才会换行

div {
  width: 100px;
  white-space: pre-wrap;
}

pre-wrap值可以看到,会保留连续空白符,且在遇到换行符和需要换行的时候都会换行

div {
  width: 100px;
  white-space: pre-line;
}

pre-line值可以看到,会合并连续空白符,且在遇到换行符和需要换行的时候都会换行

line-break

此属性用于指定如何断行
属性值:auto | loose | normal | strict | anywhere
目前还是一个处在Working Draft的阶段,w3c地址
在chrome中测试发现这几个属性值并未想官方阐述的那样对文本产生换行的影响,需要持续关注未来的进展

hyphens

此属性告诉浏览器在换行时使用连字符连接单词
属性值:none | manual | auto
来看具体例子:

abashdgsgdjagdjasddnsadvadfjasdgagdagsjdgasgdajsghsa
test test Strawberry test test test test test test test test
div {
  width: 100px;
  hyphens: none;
}

当属性值为none时,只会在有空白符的地方换行

abashdgsgdjagdjasddnsad-vadfjasdgagdagsjdgasgdajsghsa
test test Strawberry test test test test test test test test
div {
  width: 100px;
  hyphens: manual;
}

从例子中可以看出,当属性值为manual的时候,只有在空白符和连接符的时候会换行

abashdgsgdjagdjasddnsadvadfjasdgagdagsjdgasgdajsghsa
test test Strawberry test test test test test test test test
div {
  width: 100px;
  hyphens: auto;
}

当值为auto时,浏览器会自己去判断可以在哪个位置断行,然后自动在断行的位置加上连接符
目前hyphens属性也处在Working Draft的阶段,w3c地址,需要大家后续的持续关注

总结

以上对css中的文本换行会用的一些属性做了简单的总结,要想处理好文本换行的问题,还需要花更多的精力去配合其他属性的使用,需要更多的时间去探索,这也是css有趣的地方,不同的组合有不同的可能。
这篇文章如果有错误或不严谨的地方,欢迎批评指正,如果喜欢,欢迎点赞收藏

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/114208.html

相关文章

  • CSS3 文本换行

    摘要:文本换行其实是个非常常用但并不起眼的特性。在中日韩文情况下,和有区别,见下图中日韩文情况下,仍旧等于没有设,浏览器选择在文字或标点符号处换行。但设成后,将不再允许断词哪怕是中日韩文,只能像英语系一样根据半角空格或标点来换行。 文本换行其实是个非常常用但并不起眼的特性。你什么都不用设,浏览器自动就会换行。例如英语,浏览器会根据容器尺寸,选择在半角空格或连字符处换行。例如中文,浏览器会选择...

    EasonTyler 评论0 收藏0
  • CSS3 文本换行

    摘要:文本换行其实是个非常常用但并不起眼的特性。在中日韩文情况下,和有区别,见下图中日韩文情况下,仍旧等于没有设,浏览器选择在文字或标点符号处换行。但设成后,将不再允许断词哪怕是中日韩文,只能像英语系一样根据半角空格或标点来换行。 文本换行其实是个非常常用但并不起眼的特性。你什么都不用设,浏览器自动就会换行。例如英语,浏览器会根据容器尺寸,选择在半角空格或连字符处换行。例如中文,浏览器会选择...

    chinafgj 评论0 收藏0
  • CSS处理文本过长或超出部分(解说一)

    摘要:在网页开发中,经常会遇到文本超出了限定的范围,尤其是屏幕尺寸的大小导致的,着实影响美观,这个时候,就需要用对其进行处理。再补充一条,比如想让内容在第二行的时候,超出部分隐藏这个处理方式的目前只兼容内核的浏览器其他方法见解说二 在网页开发中,经常会遇到文本超出了限定的范围,尤其是屏幕尺寸的大小导致的,着实影响美观,这个时候,就需要用css对其进行处理。 下面的方法是我在实际工作中总结...

    Bamboy 评论0 收藏0
  • HTML与CSS中的文本个人分享

    摘要:文本标题元素注意在一个页面中最好只使用一个标题因为浏览器只会抓取一个多了没用示例代码标题元素元素默认效果是显示最大显示最小默认效果是由浏览器自带样式提供可以通过进行修改每个标题元素是独占一行并且是垂直排列在实际开发中常用的标题元素最 文本 标题元素 注意: 在一个HTML页面中最好只使用一个标题 因为浏览器只会抓取一个多了没用 示例代码: 一花一世界 一叶一孤城 娃哈哈 爽歪歪...

    MartinHan 评论0 收藏0
  • HTML与CSS中的文本个人分享

    摘要:文本标题元素注意在一个页面中最好只使用一个标题因为浏览器只会抓取一个多了没用示例代码标题元素元素默认效果是显示最大显示最小默认效果是由浏览器自带样式提供可以通过进行修改每个标题元素是独占一行并且是垂直排列在实际开发中常用的标题元素最 文本 标题元素 注意: 在一个HTML页面中最好只使用一个标题 因为浏览器只会抓取一个多了没用 示例代码: 一花一世界 一叶一孤城 娃哈哈 爽歪歪...

    iliyaku 评论0 收藏0

发表评论

0条评论

Caizhenhao

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<