要点: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.