HTML空格处理

By yesmore on 2021-09-06
阅读时间 3 分钟
文章共 938
阅读量

要点:HTML中使用空格、CSS方式空格

HTML的5种空格表示

HTML提供了5种空格实体(space entity),它们拥有不同的宽度,非断行空格( )是常规空格的宽度,可运行于所有主流浏览器。其他几种空格(       ‌‍)在不同浏览器中宽度各异。

 

不换行空格,全称No-Break Space,它是最常见和我们使用最多的空格,大多数的人可能只接触了 ,它是按下space键产生的空格。在HTML中,如果你用空格键产生此空格,空格是不会累加的(只算1个)。要使用html实体表示才可累加,该空格占据宽度受字体影响明显而强烈。

 

“半角空格”,全称是En Space,en是字体排印学的计量单位,为em宽度的一半。根据定义,它等同于字体度的一半(如16px字体中就是8px)。名义上是小写字母n的宽度。此空格传承空格家族一贯的特性:透明的,此空格有个相当稳健的特性,

其占据的宽度正好是1/2个中文宽度,而且基本上不受字体影响。

 

“全角空格”,全称是Em Space,em是字体排印学的计量单位,相当于当前指定的点数。例如,1 em在16px的字体中就是16px。此空格也传承空格家族一贯的特性:透明的,此空格也有个相当稳健的特性,

其占据的宽度正好是1个中文宽度,而且基本上不受字体影响。

 

窄空格,全称是Thin Space。我们不妨称之为“瘦弱空格”,就是该空格长得比较瘦弱,身体单薄,占据的宽度比较小。它是em之六分之一宽。

‌

零宽不连字,全称是Zero Width Non Joiner,简称“ZWNJ”,是一个不打印字符,放在电子文本的两个字符之间,抑制本来会发生的连字,而是以这两个字符原本的字形来绘制。Unicode中的零宽不连字字符映射为“”(zero width non-joiner,U+200C),HTML字符值引用为: ‌

‍

零宽连字,全称是Zero Width Joiner,简称“ZWJ”,是一个不打印字符,放在某些需要复杂排版语言(如阿拉伯语、印地语)的两个字符之间,使得这两个本不会发生连字的字符产生了连字效果。零宽连字符的Unicode码位是U+200D (HTML: ‍ ‍)。

此外,浏览器还会把以下字符当作空白进行解析:空格( )、制表位(	)、换行(
)和回车(
)还有( )等等。

CSS 的方式空格

white-space

CSS中当 white-space 属性取值为pre时,浏览器会保留文本中的空格和换行,例如:

1
<div style="white-space:pre">AA   BB<div> 

显示效果为: AA BB

white-space的更多属性参考:CSS 的空格处理

letter-spacing

CSS的 letter-spacing 属性用于设置文本中字符之间的间隔,例如:

1
<div style="letter-spacing:5px;">欢迎光临!</div>

显示效果为: 欢 迎 光 临 !

word-spacing

CSS的 word-spacing 属性用于设置文本中单词之间的间隔,例如:

1
<div style="word-spacing:5px">Happy new year!</div> 

显示效果为: Happy new year!

text-indent

text-indent属性用于设置首行缩进,它的取值可以是一个带单位的长度值,浏览器会在段落的首行开始处设置指定长度的空白。比如:

1
<div style="text-indent:2rem">欢迎光临!</div>
欢迎光临!

Tips: Please indicate the source and original author when reprinting or quoting this article.