广告
返回顶部
首页 > 资讯 > 前端开发 > node.js >强制换行与强制不换行的区别有哪些
  • 202
分享到

强制换行与强制不换行的区别有哪些

2024-04-02 19:04:59 202人浏览 八月长安
摘要

这篇文章主要讲解了“强制换行与强制不换行的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“强制换行与强制不换行的区别有哪些”吧!强制换行与强制不换行

这篇文章主要讲解了“强制换行与强制不换行的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“强制换行与强制不换行的区别有哪些”吧!

强制换行与强制不换行用到的属性

我们一般控制换行所用到的CSS属性一共有三个:Word-wrap; word-break; white-space。这三个属性可以说是专为了文字断行而创造出来的。首先我们得知道这三个属性到底是做什么用地:

word-wrap语法:

word-wrap: nORMal(默认) | break-word
各个浏览器均能识别

参数:

normal: 允许内容顶开指定的容器边界。
break-word: 内容将在边界内换行。必要时会触发word-break(注意:请分辨清楚word-break和break-word这俩个是不同的东西,一为属性另为参数)。

说明:

word-wrap是控制是否“为词断行”的,设置或检索当前行超过指定容器的边界时是否断开转行。中文没有任何问题,英文语句也没问题。但是对于长串的英文,就不起作用。

范例:

congratulation这个单词属于长串英文,word-wrap:break-word整个单词看成一个整体,如果该行末端宽度不够显示整个单词,它会自动把整个单词放到下一行,而不会把单词截断,这就是对于长串文字不起作用的解释。word-wrap:normal是默认情况,英文单词不被拆开。


结论:

作用范围仅为div这类标准块级元素,th,td这类table元素虽然识别但是没有效果(如果为td,th加上宽度word-wrap在IE下是能够发挥效果的,但根据完全兼容性方便记忆角度上来说还是以前面的结论为准)。

word-break语法:

word-break: normal(默认) | break-all | keep-all
Firefox、Opera不能识别

参数:

normal: 依照亚洲语言和非亚洲语言的文本规则,允许在字内换行。
break-all: 该行为与亚洲语言的normal相同。也允许非亚洲语言文本行的任意字内断开。该值适合包含一些非亚洲文本的亚洲文本。
keep-all: 与所有非亚洲语言的normal相同。对于中文,韩文,日文,不允许字断开。适合包含少量亚洲文本的非亚洲文本。

说明:

word-break:break-all,是断开单词。在单词到边界时,下个字母自动到下一行。主要解决了长串英文的问题(恰恰弥补了上面word-wrap:break-word对于长串文字不起作用的缺陷)。

范例:

继续以上面congratulation这个单词属于长串英文,word-break:break-all它会把单词截断,该行末端就会变成类似conra(congratulation的前端部分),下一行为tulation(conguatulation)的后端部分了。
word-break:keep-all,是指Chinese, Japanese, and Korean不断词。即只用此时,不用word-wrap,中文就不会换行了。(英文语句正常。)

结论:

作用范围仅为div这类标准块级元素,th,td这类table元素虽然识别但是没有效果(经测试Chrome下word-break:break-all是有效果的,但根据完全兼容性方便记忆角度上来说还是以前面的结论为准)。Firefox,Opera是无法识别word-break的,更不用提Firefox下的th,td中使用word-break的效果了。

white-space语法:
white-space: normal(默认) | pre | nowrap

参数:

normal: 默认。空白会被浏览器忽略。
pre: 空白会被浏览器保留。其行为方式类似html中的pre标签。
nowrap: 文本不会换行,文本会在在同一行上继续,直到遇到br标签为止。

说明:

对于pre属性,其实就是HTML中连续的多个空白符会被合并,然后为了不让他合并(最常用的场合就是表示代码文字缩进)让其中的空白符继续保留而不需要我们增加额外的样式和标签来控制它的缩进和换行。pre标签的原理也是一样的内部默认有了个white-space:pre。
对于nowrap属性,这个是强制不换行核心,一般强制不换行就是利用这个属性。Firefox的div和td中,以及IE的div中,均没有问题。唯一的瑕疵就是在IE的td中会有一个问题,如果td没有指定宽度,则nowrap仍然有效,如果td有宽度,并且文字中无标点、无空格(例如中文长串文字),nowrap则不再有效。解决方式就是可以加word-break:keep-all;可以解决此问题。

总结强制换行:

如果在div这类标准块级元素中需要强制换行,最普遍的方案那就是word-wrap:break-word; word-break:break-all;此方式的缺点就是会导致如果恰巧该行末端宽为一个长串英文单词,那么该单词会被撕开的尴尬样式(而且FF不识别word-break,反而不会撕开这个单词)。个人认为如果你这个div里面放的类似于URL这个长串地址,那么用此方案是非常不错的选择(注意:由于FF不识别word-break,所以无法保证每行末端会整齐的断开URL单词,但这也是无奈的选择)。如果不是放置URL这类可以断开的长串英文,而是英文句子的话,那么使用word-wrap:break-word;即可。至于网上看到有word-wrap:break-word; overflow:hidden;这么个写法,据说可以兼容IE和FF,但经过亲自测试似乎没有什么特别效果。当然,如果你有更好的方案也可以留言参与讨论,这里也十分欢迎您的意见。

如果是在td,th这类table元素中需要强制换行,个人比较推荐的方式为:先为table设定table-layout:fixed,至于为什么要设定这个属性可参考我的《拿什么来拯救你,我的Table》这篇文章,里面有比较详细的说明。基本上设定完这个属性后基本的换行问题都能够解决而不会出现table中td,th因为里面各个内容的多寡发生抢夺其他td,th宽度的情形发生。这时如果你依旧有强制换行问题,那么在此td中内部加一层div,那么情况就会像上面讨论的方式来解决。

总结强制不换行:

强制不换行的问题到是比较容易分析的,就如上面所讨论的那样使用white-space:nowrap,Firefox的div和td中,以及IE的div中,均没有问题。唯一的瑕疵就是在IE的td中会有一个问题,如果td没有指定宽度,则nowrap仍然有效,如果td有宽度,并且文字中无标点、无空格(例如中文长串文字),nowrap则不再有效。解决方式就是可以加word-break:keep-all;可以解决此问题。综合下来,比较稳妥的方式是在文字与td之间再套一层div,然后使用nowrap,那么就是强制不换行。注意这时候很有可能文字会过多导致溢出容器,所以你还得加一个overflow:hidden,防止溢出容器,这样子就可以兼容各个浏览器了。

感谢各位的阅读,以上就是“强制换行与强制不换行的区别有哪些”的内容了,经过本文的学习后,相信大家对强制换行与强制不换行的区别有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: 强制换行与强制不换行的区别有哪些

本文链接: https://www.lsjlt.com/news/82346.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 强制换行与强制不换行的区别有哪些
    这篇文章主要讲解了“强制换行与强制不换行的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“强制换行与强制不换行的区别有哪些”吧!强制换行与强制不换行...
    99+
    2022-10-19
  • CSS怎么强制中英文换行与不换行
    这篇文章主要讲解了“CSS怎么强制中英文换行与不换行”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS怎么强制中英文换行与不换行”吧! ...
    99+
    2022-10-19
  • html5文字如何强制不换行
    这篇“html5文字如何强制不换行”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“html5...
    99+
    2022-10-19
  • CSS怎么实现容器内强制换行和不换行
    这篇文章主要介绍“CSS怎么实现容器内强制换行和不换行”,在日常操作中,相信很多人在CSS怎么实现容器内强制换行和不换行问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS怎...
    99+
    2022-10-19
  • CSS强制性换行的方法
    这篇文章主要讲解了“CSS强制性换行的方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS强制性换行的方法”吧!一般情况下,元素拥有默认的white-s...
    99+
    2022-10-19
  • 怎么在css3中设置强制不换行
    本篇文章给大家分享的是有关怎么在css3中设置强制不换行,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。强制不换行p{    white-...
    99+
    2023-06-15
  • css 英文强制不换行代码是什么
    本教程操作环境:Windows10系统、css3版、DELL G3电脑css 英文强制不换行代码是什么?CSS 英文、中文强制换行与不换行的代码1. word-break:break-all; 只对英文起作用,以字母作为换行依据2. wor...
    99+
    2023-05-14
    css
  • css英文强制不换行的方法是什么
    这篇文章主要介绍“css英文强制不换行的方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“css英文强制不换行的方法是什么”文章能帮助大家解决问题。css英文强制不换行代码是“white-sp...
    99+
    2023-07-05
  • JavaScript强制类型转换方法有哪些
    这篇文章主要介绍“JavaScript强制类型转换方法有哪些”,在日常操作中,相信很多人在JavaScript强制类型转换方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解...
    99+
    2022-10-19
  • C++强制类型转换的方式有哪些
    本篇内容主要讲解“C++强制类型转换的方式有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C++强制类型转换的方式有哪些”吧!1 C++类型转换本质1.1 自动类型转换(隐式)利用编译器内置...
    99+
    2023-06-30
  • javascript进行强制类型转换的方法
    这篇文章给大家分享的是有关javascript进行强制类型转换的方法的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。强制转换方法:1、使用ToString()、ToNumber()或ToBoolean()方法;2、...
    99+
    2023-06-14
  • javascript进行类型强制转换的方法
    小编给大家分享一下javascript进行类型强制转换的方法,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!强制转换方法:1、使用String()、Number()或toString()函数进行字符串与数字之间的显示类型转换...
    99+
    2023-06-15
  • HTML中nob强制不换行标签元素怎么用
    这篇文章给大家分享的是有关HTML中nob强制不换行标签元素怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。   在网页排版布局中比如文章列表标题排版,无论多少文字均不希望...
    99+
    2022-10-19
  • c++强制转换数据类型的方法有哪些
    在C++中,有以下几种强制转换数据类型的方法:1. 静态转换(static_cast):用于基本数据类型之间的转换,以及具有继承关系...
    99+
    2023-10-18
    c++
  • java数据类型强制转换的方法有哪些
    在Java中,有两种方法可以进行数据类型的强制转换:1. 自动类型转换(隐式类型转换):当把一个小范围的数据类型赋值给一个大范围的数...
    99+
    2023-08-17
    java
  • 好程序员web前端分享HTML元素强制不换行
    好程序员web前端分享HTML元素强制不换行,HTML 中 nowrap是用来强制不换行的   在排版中   对包裹plain text的标签使用nowrap属性即刻实现强制不换行.   如:   强...
    99+
    2023-06-03
  • html中如何使用<nobr>强制不换行标签元素
    这篇文章主要介绍html中如何使用<nobr>强制不换行标签元素,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!html <nobr>强制不换行标签-禁止内容换...
    99+
    2022-10-19
  • css如何使文本溢出边界不换行强制在一行内显示
    这篇文章主要为大家展示了“css如何使文本溢出边界不换行强制在一行内显示”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css如何使文本溢出边界不换行强制在一行内显示”这篇文章吧。使文本溢出边界不...
    99+
    2023-06-17
  • html5不能换行的标签有哪些
    本篇内容介绍了“html5不能换行的标签有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读...
    99+
    2022-10-19
  • CSS中几个与换行有关的属性有哪些
    这篇文章主要讲解了“CSS中几个与换行有关的属性有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS中几个与换行有关的属性有哪些”吧!word-wra...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作