全角半角 && 6种空白空格的区别

  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: ‍ ‍)。

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

在Java Web开发中,空格符的使用是一个常见的问题。空格符在HTML中会被浏览器解析为一个空白字符,但在某些情况下,空格符可能会导致布局问题或文本显示异常。以下是一些常见的空格符处理方法: 1. **使用CSS处理空格**: - `white-space`属性:可以控制空白字符的处理方式。例如,`white-space: nowrap;`可以防止文本换行。 - `text-indent`属性:可以设置文本的首行缩进。 2. **使用HTML实体**: - ` `:表示不间断空格,用于在HTML中插入空格。 - ` `和` `:分别表示半角空格全角空格。 3. **在Java代码中处理空格**: - 使用`String.trim()`方法:可以去除字符串两端的空白字符。 - 使用`String.replaceAll("\\s+", " ")`:可以将多个连续的空白字符替换为一个空格。 4. **在JSP页面中处理空格**: - 使用JSTL标签库中的`<c:out>`标签:可以自动转义特殊字符,包括空格。 - 使用EL表达式:可以结合JSTL标签库进行更灵活的处理。 示例代码: ```html <!DOCTYPE html> <html> <head> <style> .no-wrap { white-space: nowrap; } .indent { text-indent: 2em; } </style> </head> <body> <p class="no-wrap">这是一个不换行的文本。</p> <p class="indent">这是一个首行缩进的文本。</p> <p>   这是使用 插入的空格。</p> <p><c:out value=" 这是一个使用JSTL处理的文本。 " /></p> </body> </html> ``` 在Java代码中: ```java String text = " 这是一个包含空格的文本。 "; text = text.trim(); // 去除两端的空白字符 text = text.replaceAll("\\s+", " "); // 将多个连续的空白字符替换为一个空格 ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值