CSS 中的 :before 和 :after 的一点小知识点

html-css025

CSS 中的 :before 和 :after 的一点小知识点,第1张

:before 选择器在被选元素的内容前面插入内容。

定义中提到,是在被选元素的 内容 前面插入内容,如下图,div 是一个容器,div 中的内容是 testDiv元素 ,css 中的 :before 和 after 都显示在 div 内部,二者分别位于 testDiv元素 内容的前后。

所以可以看到,伪元素也是被选元素的内容,只是会插入到被选元素原本内容的前后。

插入的伪元素默认是 display 属性,如果想要为伪元素设置宽高等,需要修改伪元素的 display 属性为 inline-block 或者 block 。

伪元素插入的位置是被选元素的 内容 的前或者后,因此本质上伪元素也是被选元素的子元素。所以定位时,被选元素就是伪元素的父元素。

如图,被选元素 test-div 设置了 position: relative ,外部元素 test-wrapper 也设置了 position: relative ,然后对被选元素的伪元素 :after 设置定位,可以看到,伪元素的位置是根据 test-div 来定位的,因此,可以验证 被选元素就是伪元素的父元素 这句话。

1楼说的是正确的(规范的)代码

但IE5/6有BUG 使这段代码在IE5/6不起作用(IE7/E8都没问题)

因此要使用其他方法

其中一种就是楼主使用的text居中

不过这个代码在Firefox和IE7/8又会失效(因为这是不规范的代码)

所以要用另一个更通用的方法--负边距

left:50%

width:800px

margin-left:-400px//请注意 边距和定位的方向要一致(同为左或右) 值是宽度的一半

实际上这里就是把元素的一边定位在网页中间 然后通过设置边距把超出的部分拉回来