酷站(www.ku0.com)-致力于为互联网从业者提供动力!

热门关键词:  企业  as  baidu  c4rp3nt3r  美女
【阿里云】采购季上云仅¥223/3年

css的空格处理的方法

来源:互联网搜集 作者:秩名 人气: 发布时间:2019-11-05
本篇文章主要介绍了css的空格处理的方法,对大家的学习或者工作具有一定的参考学习价值,感兴趣的小伙伴们可以参考一下,也感谢大家对酷站(ku0.com)的支持。

1、空格规则

HTML 代码的空格通常会被浏览器忽略。
 

<p>  hello  world  </p>

上面是一行 HTML 代码,文字的前部、内部和后部各有两个空格。

浏览器的输出结果如下: hello world

可以看到,文字的前部和后部的空格都会忽略,内部的连续空格只会算作一个。这就是浏览器处理空格的基本规则。

如果希望空格原样输出,可以使用 <pre> 标签。
 
 
<pre>  hello  world  </pre>
另一种方法是,改用 HTML 实体 表示空格。
<p>  hello  world  </p>

2、空格字符

HTML 处理空格的规则,适用于多种字符。除了普通的空格键,还包括制表符(t)和换行符(r和n)。

浏览器会自动把这些符号转成普通的空格键。
 
 
<p>hello
world</p>

上面代码中,文本内部包含了一个换行符,浏览器视同为空格,输出结果如下: hello world

所以,文本内部的换行是无效的(除非文本放在 <pre> 标签内)。
 
 
<p>hello<br>world</p>

上面代码使用

标签显式表示换行

3、CSS white-space 属性

HTML 语言的空格处理,基本上就是直接过滤。这样的处理过于粗糙,完全忽视了原始文本内部的空格可能是有意义的。

CSS 提供了一个white-space属性,可以提供更精确一点的空格处理方式。该属性共有六个值,除了一个通用的inherit(继承父元素),下面依次介绍剩下的五个值。

3.1 white-space: normal

white-space属性的默认值为normal,表示浏览器以正常方式处理空格。
 

 
html:
    <p>  hellohellohello hello
    world
    </p>
style:
    p {
        width: 100px;
        background: red;
    }

上面代码中,文本前部有两个空格,内部有一个长单词和一个换行符。

文首的空格被忽略。由于容器太窄,第一个单词溢出容器,然后在后面一个空格处换行。文本内部的换行符自动转成了空格。

3.2 white-space: nowrap

white-space属性为nowrap时,不会因为超出容器宽度而发生换行。
 
 
p {
    white-space: nowrap;
}
 

所有文本显示为一行,不会换行。

3.3 white-space: pre

white-space属性为pre时,就按照 <pre> 标签的方式处理。
 

 
p {
    white-space: pre;
}

上面结果与原始文本完全一致,所有空格和换行符都保留了。

3.4 white-space: pre-wrap

white-space属性为pre-wrap时,基本还是按照 <pre> 标签的方式处理,唯一区别是超出容器宽度时,会发生换行。
 
 
p {
    white-space: pre-wrap;
}

文首的空格、内部的空格和换行符都保留了,超出容器的地方发生了折行。

3.5 white-space: pre-line

white-space属性为pre-line时,意为保留换行符。除了换行符会原样输出,其他都与white-space:normal规则一致。
 
 
p {
    white-space: pre-line;
}

除了文本内部的换行符没有转成空格,其他都与normal的处理规则一致。这对于诗歌类型的文本很有用。

版权声明:本文内容来源于互联网或用户自行发布贡献,该文观点仅代表原作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 959677720#qq.cn(#换@) 举报,一经查实,本站将立刻删除。
原文链接:https://www.jb51.net/css/699696.html

相关文章

  • CSS盒子隐藏/显示后再最上层的实现方法

    CSS盒子隐藏/显示后再最上层的实现方法

    ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76......
    05-17
  • css3实现背景模糊的三种方式

    css3实现背景模糊的三种方式

    一、普通背景模糊 代码: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 Style html, body { width: 100%; height: 100%; } * { margin: 0; padding: 0; } ......
    05-17
  • flex布局中保持内容不超出容器的解决办法

    flex布局中保持内容不超出容器的解决办法

    在移动端,flex 布局很好用,它能够根据设备宽度来自动调整容器的宽度,用起来很方便,已经越来越离不开它,但是最近在做项目的时候发现一个问题。 就是在一个设置了 flex:1 的容器中,如果文字很长,这时候文字就会超出容器,而不是呆在......
    05-17
  • 详解CSS继承inherit属性的方法

    详解CSS继承inherit属性的方法

    给定一张有如下背景图的 div: 制作如下的倒影效果: 方法很多,但是我们当然要寻找最快最便捷的方法,至少得是无论图片怎么变化, div 大小怎么变化,我们都不用去改我们的代码。 法一:-webkit-box-reflect 这是一个十分新的 CSS 属性......
    05-10
  • 利用定位使元素居中(web端页面布局小技巧)

    利用定位使元素居中(web端页面布局小技巧)

    元素在浏览器窗口居中的方法 这里先给出代码块,如果有同学已经看出来点眉目可以先自己尝试一下。 position:fixed; /*给想要居中的元素设置*/left:50%; /*或者right:50%*/top:50%; /*或者bottom:50%*/margin-left:-元素宽度的一半; /*或......
    05-06
  • 基于ccs3的timeline时间线的实现

    基于ccs3的timeline时间线的实现

    在web项目中我们经常要使用时间轴(timeline)控件。本文提供一种基于CSS3的可逐项展开的timeline,在各展开项中可以嵌入文本、图片、视频等元素。运行效果如下: 实现 该控件的实现过程较为简单,主要由test.html文件和timeline.css文件......
    05-01
  • 详解CSS3中的Flex布局

    详解CSS3中的Flex布局

    Flexbox布局模块旨在提供一个更有效的方式,在一个容器里面去布局分配空间。即使容器的大小是未知的,或者动态变化的。 Flex 布局背后的主要思想是让容器能够改变其项目的宽度 / 高度(和顺序) ,以最佳地填充可用空间(主要是适应各种显示......
    04-27
  • css中的匹配问题的详细介绍

    css中的匹配问题的详细介绍

    问题描述 众所周知在写 css的时候,会根据html 中类的定义或者 id 的定义来写相应的 css代码。给不同的类定义不同的样式,当然为了能够少写一些代码,大家就会在css 中引用匹配。匹配有模糊匹配和全局匹配。匹配的方式有几种。当然也可以......
    04-25
  • css3中less实现文字长阴影(long shadow)的代码

    css3中less实现文字长阴影(long shadow)的代码

    问题 实现如下图效果 主要知识点 css中的字体阴影 text-shadowless 语法中的 loops 和 merge 代码 div class=long-shadow屮艸芔茻/div .loop(@counter) when (@counter 0) { .loop((@counter - 1)); text-shadow+: (1px * @counter) (1px......
    04-25
  • css3实现元素弧线运动

    css3实现元素弧线运动

    如何使用CSS控制元素弧线运动 我们都知道,CSS3的新属性transfrom过渡效果可以实现元素位移、旋转、缩放。结合animation属性,就可以实现元素的动画效果。但是如何通过css实现元素实现弧线运动呢: 如上图动画效果所示,圆球弧线运动,分......
    04-25

最新更新