在行内元素前注入一个换行,right的使用说明
分类:前端技术

在行内元素前注入一个换行

2016/06/28 · CSS · 行内元素

原文出处: Chris Coyier   译文出处:众成翻译   

我遇到了一个小问题,我有一个 span 在 header 中,而我想要在 span 的前面产生一个换行。郑重声明,在 span 前面插入一个 <br> 标签当然没问题(而事实上,你还可以显示/隐藏这个标签,这非常有用)。但是…不得不用 HTML 去做一个布局相关的事情始终感觉有点奇怪。

因此,让我们来深入探索一下,在这个探索中,我们会多次说到“然而…”。

XHTML

<h1 class="one"> Break right after this <!-- <br> could go here, but can we do it with CSS? --> <span> and before this </span> </h1>

1
2
3
4
5
6
7
8
9
10
11
<h1 class="one">
 
  Break right after this
 
  <!-- <br> could go here, but can we do it with CSS? -->
 
  <span>
    and before this
  </span>
 
</h1>

前言:这是最近翻译的一篇文章

点评:CSS中很多时候会用到浮动来布局,也就是经常见到的float:left或者float:right,简单点来说,前者是左浮动(往左侧向前边的非浮动元素飘,全是飘得元素的话,就按照流式来浮动从左到右,放不下则换行),后者是右浮(往右飘)动。但仅仅是如此吗?

块级元素能做到

不同于 `,我们可以使用一个

`,而之所以用 div 可以是因为它是一个块级元素。

但是我们有使用 span 的理由,因为设计上要求我们用 span。在换行之后的文本应该是一个行内/行内块元素,因为我们可能想给它一个背景或者 padding 或者其他什么。

图片 1

 

 No! 

你可以通过伪元素插入换行

这很容易:

CSS

h1 span::before { content: "A"; }

1
2
3
h1 span::before {
  content: "A";
}

然而… `` 是一个行内元素。换行不会产生任何效果!就像真正的回车换行一样不产生。

我们可以通过样式让空白符生效,来强制让换行有效…

CSS

h1.two span::before { content: "A"; white-space: pre; }

1
2
3
4
h1.two span::before {
  content: "A";
  white-space: pre;
}

这样实际有效果了。然而… 由于 padding 和背景存在,它把左 padding 的部分留在了上一行:

图片 2

我们可以使用 box-decoration-break: clone; 来修复这个“左边缘环绕”的问题,然而… 它会导致上一行产生更大的黑块:(此处不明白的同学可以看这个例子——译者注)

图片 3

box-decoration-break 对于处理一些问题来说好极了,但不包括这个问题。

如果我们将 span 变成 inline-block,那么换行将会发生在那个块里面,这也不是我们想要的效果:

图片 4

将伪元素设置成块级元素,让 span 保持行内元素,这样也不行:

图片 5

我在header标签开头忘里边加入一个span标签的时候,有一点小问题。我总是想确保在span标签之前能够换行。明确地讲,在标签前边加入<br> 并没有什么错误。(事实上这是非常有用的办法)。但是用HTML标签实现这个效果总让人觉得怪怪的。

要注意以下几点: 
1、 浮动元素会被自动设置成块级元素,相当于给元素设置了display:block(块级元素能设置宽和高,而行内元素则不可以)。 
2、 浮动元素后边的非浮动元素显示问题。 
3、 多个浮动方向一致的元素使用流式排列,此时要注意浮动元素的高度。 
4、子元素全为浮动元素的元素高度自适应问题。 

你可能会有点奇怪,为何不直接将实际的文本写在伪元素里

这是 Aaron Bushnell 想出的办法。这个技巧是让 span 成为块级元素,然后把文本通过伪元素插入进去,以伪元素作为行内元素添加样式。

CSS

h1 span { display: block; } h1 span::before { content: attr(data-text); background: black; padding: 1px 8px; }

1
2
3
4
5
6
7
8
h1 span {
  display: block;
}
h1 span::before {
  content: attr(data-text);
  background: black;
  padding: 1px 8px;
}

图片 6

这样可以!然而…

我一直是伪元素技巧的簇拥,但是这么用有点危险,因为你可能破坏了可访问性。我认为一些读屏软件会读伪元素,但不是所有的都会,也不是所有的都打算支持。更何况这种方式下你不能拷贝和粘贴所有的文本,尽管这些文本完整地出现在 HTML 文档里。

所以让我们探索更多的可能。

以下详细分析四个问题。 

利用 table 布局

我最喜欢的方式是由 Thierry Koblentz 提出的。只需要给 span 设置 display:table; 就行了。当然这不是真正的表格数据,但没关系。通过 CSS 将元素强制用 table 布局以利用 table 布局独特的布局属性,它唯一的问题仅仅是——不语义化。

CSS

h1 span { display: table; }

1
2
3
h1 span {
  display: table;
}

图片 7

HTML:

一、浮动元素自动变块级元素  首先说说块级元素和行内元素区别,简单的来说,块级元素独占一行,可以设置宽高以及边距,行内元素不会独占一行,设置宽高行距等不会起效。常见的块级元素有:h1~h6、p、div、ul、table,常见的行内元素有:span、a、input、select等。 

在线例子

包括使用 <br> 的那个例子,那样做也是好的。

例子:在一个 header 元素中的行内元素前尝试插入一个换行。

1 赞 3 收藏 评论

图片 8

<h1 class="one">

示例代码: 
No! 
要注意以下几点: 
1、 浮动元素会被自动设置成块级元素,相当于给元素设置了display:block(块级元素能设置宽和高,而行内元素则不可以)。 
2、 浮动元素后边的非浮动元素显示问题。 
3、 多个浮动方向一致的元素使用流式排列,此时要注意浮动元素的高度。 
4、子元素全为浮动元素的元素高度自适应问题。 

 Break right after this

以下详细分析四个问题。 

 <!-- <br> could go here, but can we do it with CSS? -->

一、浮动元素自动变块级元素  首先说说块级元素和行内元素区别,简单的来说,块级元素独占一行,可以设置宽高以及边距,行内元素不会独占一行,设置宽高行距等不会起效。常见的块级元素有:h1~h6、p、div、ul、table,常见的行内元素有:span、a、input、select等。 

 <span>

示例代码: 
No! 
要注意以下几点: 
1、 浮动元素会被自动设置成块级元素,相当于给元素设置了display:block(块级元素能设置宽和高,而行内元素则不可以)。 
2、 浮动元素后边的非浮动元素显示问题。 
3、 多个浮动方向一致的元素使用流式排列,此时要注意浮动元素的高度。 
4、子元素全为浮动元素的元素高度自适应问题。 

   and before this

以下详细分析四个问题。 

 </span>

一、浮动元素自动变块级元素  首先说说块级元素和行内元素区别,简单的来说,块级元素独占一行,可以设置宽高以及边距,行内元素不会独占一行,设置宽高行距等不会起效。常见的块级元素有:h1~h6、p、div、ul、table,常见的行内元素有:span、a、input、select等。 

</h1>

示例代码: 

用块级元素实现它

除了<span> ,我们可以用<div>,我们只需用div的默认块级特性来实现它。

但是考虑到设计和语义,我们用span更好些。在文字换行处,我们可以使用inline/inline-block,因为方便我们设置background和padding值等等

图片 9

复制代码

在换行处使用伪元素

很简单:

css

h1 span::before {

 content: "A";

}

 

但是,这个<span> 是一个行内元素。换行没有效果。

我们可以通过设置white-space: pre来强迫它换行

h1.two span::before {

 content: "A";

 white-space: pre;

}

这样做确实换行了,但是由于padding和background的原因,在换行的时候留了一个黑块,

图片 10

我们可以通过使用 box-decoration-break: clone修复这个尴尬的左边黑块,但是,结果却是产生了一个更大的黑块。

图片 11

box-decoration-break对一些问题非常有效,但是在这里失效了。

 

如果我们给这个span设置成inline-block,这个断行出就会和块级元素在一行,也不是我们想要的结果:

 

图片 12

 

让这个伪元素块级化和单独使用span也没有效果:

图片 13

 

利用伪元素

这是亚伦-布什内尔的想法。这个窍门是让span块级化,但是通过伪元素给它同时添加文字和样式让他也是一个行内元素。

css

h1 span {

 display: block;

}

h1 span::before {

 content: attr(data-text);

 background: black;

 padding: 1px 8px;

}

图片 14

 

我一直很喜欢利用伪元素来做一些技巧,但是这种方法可能会有点危险,如果你使用不好的话。我想一些屏幕阅读器可以读出伪元素,但是也不完全。是,他们也不会故意这样做。更不要说你不能复制和粘贴所有的文字,这种方式。至少文本仍然保持完全的HTML!

 

代码如下:

利用表格布局

我最喜欢的方法是来自蒂埃里科布伦茨。仅仅给span设置:display: table;你完成之后。这不是表格数据,但是这不重要。你需要清楚的是强制使用css的表格布局是利用表格的独有特性。这并不具有语义。

css

h1 span {

 display: table

 

英文出处:

<div style="height: 200px; width: 200px;"> 
<span style="float: left; width: 150px; height: 150px; margin: 5px; padding: 5px; 
border: solid 1px red; background-color: Olive;">浮动元素span</span> 
</div> 
<div style="height: 200px; width: 200px;"> 
<span style="width: 150px; height: 150px; margin: 5px; padding: 5px; border: solid 1px red; 
background-color: Olive;">浮动元素span</span> 
</div> 

 

效果如下: 
图片 15
二、浮动元素后的非浮动元素问题  浮动元素后边的元素若是非浮动行内元素且因为定位产生重叠时,行内元素边框、背景和内容都在该浮动元素“之上”显示,若是非浮动块级元素跟在浮动元素后边且在定位后产生重叠时,该块级元素边框和背景在该浮动元素“之下”显示,只有内容在浮动元素不在浮动元素“之下”显示。 
示例代码如下: 

复制代码

代码如下:

<div style="width: 600px; height: 500px; border: solid 1px blue; background-color: yellow;"> 
<div style="float: left; width: 250px; height: 250px; border: solid 1px Aqua; background-color: gray; 
margin: 10px 0 0 10px;"> 
浮动DIV</div> 
<div style="background-color: red; border: solid 1px green; width: 300px; height: 150px;"> 
跟在浮动元素后边的DIV</div> 
<span style="background-color: red; border: solid 1px green; margin: 0 0 0 -50px;"> 
跟在浮动元素后边的span</span> 
</div> 

效果图如下: 
图片 16

从图中可以看出来,跟在浮动div后边的div背景以及边框被压在了底下,内容却没有,span整体都在浮动div之上显示。 

不过在ie6这个效果却很怪异,如图:

图片 17
浮动元素没有压在非浮动div之上,反而把span压住了。
三、多个并列同方向浮动元素高度不一致问题  多个同方向浮动元素若是高度不一致的话,很可能会得到意外的效果,跟你想要的布局差别很大。多个同方向浮动元素一般是按照流式布局,一行满了则自动换行,也就是类似于以下效果: 
图片 18
但各个浮动元素高度不一致的话效果很可能出现下边的情况: 
图片 19
很意外吧,主要排列到元素7的时候,一行已经显示不下了,所以要换行,但此处换行并不是从行头开始,而是从元素5那开始,因为元素5比元素6高很多导致。 
四、子元素全为浮动元素高度自适应问题  由于元素浮动后脱离了文档流,所以父元素是无法根据元素来自适应的。解决此问题最常用的办法由两种,第一种就是在所有浮动元素后加: 
<div style="clear:both;height:0px;"></div> 
第二种办法,使用万能clear: 

复制代码

代码如下:

.clearfix:after 

visibility: hidden; 
display: block; 
font-size: 0; 
content: "."; 
clear: both; 
height: 0; 

* html .clearfix 

zoom: 1; 

*:first-child html .clearfix 

zoom: 1; 

然后在你需要自适应的元素上加上class=” clearfix”即可。详细请参考: 

你真的理解clear:both吗  在开发中,从美工MM给你Html代码中,肯定能经常看”<div style="clear:both;"></div>”这样的代码,但是你真的能明白它是做什么用的吗? 
如: 

复制代码

代码如下:

<div style="border:2px solid red;"> 
<div style="float:left;width:80px;height:80px;border:1px solid blue;">TEST DIV</div> 
<div style="clear:both;"></div> 
</div> 

你可以将此部分代码放到一个HTML页面看看效果,然后在去掉”<div style="clear:both;"></div>”看一下效果,就知道这句话的作用了。 
如图: 
(1)有clear:both的: 

图片 20

(2)无clear:both的

图片 21
这样看,应该就一目了然了:原来后边的Clear:both;其实就是利用清除浮动来把外层的div撑开,所以有时候,我们在将内部div都设置成浮动之后,就会发现,外层div的背景没有显示,原因就是外层的div没有撑开,太小,所以能看到的背景仅限于一条线。 

但这种办法就是最好了的吗? 
我这么说,当然答案就不是了。可以采用通过Hack实现: 

复制代码

代码如下:

<style> 
.clearfix:after{ 
visibility: hidden; 
display: block; 
font-size: 0; 
content: "."; 
clear: both; 
height: 0; 

* html .clearfix{zoom: 1;} 
*:first-child html .clearfix{zoom: 1;} 
</style> 
<div class="clearfix" style="border: 2px solid red;"> 
<div style="float: left; width: 80px; height: 80px; border: 1px solid blue;"> 
TEST DIV</div> 
</div> 

看完解决办法,咱们来看里边的原理: 
(1)、首先是利用:after这个伪类来兼容FF、Chrome等支持标准的浏览器。 
:after伪类IE不支持,它用来和content属性一起使用设置在对象后的内容,例如: 
a:after{content:"(link)";} 
这个CSS将会让a标签内的文本后边加上link文本文字。 

(2)、利用“* html”这个只有IE6认识的选择符,设置缩放属性“zoom: 1;”实现兼容IE6。 

(3)、利用“*:first-child

  • html”这个只有IE7认识的选择符,设置缩放属性“zoom: 1;”实现兼容IE7。 

本文由pc28.am发布于前端技术,转载请注明出处:在行内元素前注入一个换行,right的使用说明

上一篇:用法教程 下一篇:没有了
猜你喜欢
热门排行
精彩图文
  • 在行内元素前注入一个换行,right的使用说明
    在行内元素前注入一个换行,right的使用说明
    在行内元素前注入一个换行 2016/06/28 · CSS ·行内元素 原文出处: ChrisCoyier   译文出处:众成翻译    我遇到了一个小问题,我有一个 span 在 header 中,而
  • 标签的用法,标签区别
    标签的用法,标签区别
    考虑 pre 标签的样式 2016/06/02 · CSS ·标签 原文出处: ChrisCoyier   译文出处:众成翻译    你可能正在使用 pre 标签。这是一个 HTML中非常特别的标签,它
  • 异步JavaScript的进步历程,函数简化异步代码
    异步JavaScript的进步历程,函数简化异步代码
    异步JavaScript进化史 2015/10/14 · CSS 本文由 伯乐在线 -cucr翻译,唐尤华校稿。未经许可,禁止转载! 英文出处:GergelyNemeth。欢迎加入翻译组。 async函数近在
  • Canvas完毕监察和控制种类页面呈现,json工控风机
    Canvas完毕监察和控制种类页面呈现,json工控风机
    传说 HTML5 Canvas 达成客车站监察和控制 2017/11/21 · HTML5 ·Canvas 初稿出处: hightopo    陪伴国内经济的长足发展,大家对安全的渴求更为高。为了防卫下列景
  • 不足挂齿的,层叠上下文
    不足挂齿的,层叠上下文
    深入领会CSS中的层叠上下文和层叠顺序 2016/01/10 · CSS ·层叠上下文 原稿出处:张鑫旭    零、凡间的道理都以想通的 在此个世界上,所有的事都有个前后