这两天看到一个CSS用法,before和after。感觉在插入内容时用起来没什么大问题,但是在调样式时,发现他们用起来灵活多变。搜到一篇博文,例子举得清楚。看到博主留言说可以转载,特地转载过来收藏。
原文地址:CSS巧用 :before和:after
以下所有代码直接复制到干净的文件里就可以运行,文件为 .html。
什么是:before和:after? 该如何使用他们?
:before是css中的一种伪元素,可用于在某个元素之前插入某些内容。
:after是css中的一种伪元素,可用于在某个元素之后插入某些内容。
下面先跑个简单的代码测试一下:
<style>
p:before{
content: "H" /*:before和:after必带技能,重要性为满5颗星*/
}
p:after{
content: "d" /*:before和:after必带技能,重要性为满5颗星*/
}
</style>
<p>ello Worl</p>
以上的代码出现在页面中的结果是“Hello World”,通过浏览器的“审查元素”(“检查”)看到的是
<p>
::before
"ello Worl"
::after
</p>
p标签内部的内容的前面会被插入一个:before伪元素,该伪元素内包含的内容是"H";而在p标签内的内容后面会被插入一个:after伪元素,该元素包含的内容是"d"。
下面我们看看平常该怎么使用他们。
1.结合border,写个对话框的样式。
首先看看怎么用border画三角形样式
<style>
.triangle{
width: 0;
height: 0;
border-left:50px solid red;
border-bottom:50px solid blue;
border-top:50px solid black;
border-right:50px solid purple
}
</style>
<div class="triangle"></div>
则结果为
对上面的样式做些修改
<style>
.triangle{
width: 0;
height: 0;
border:50px solid transparent; /*这里我们将元素的边框宽度设置为50px,transparent表示边框颜色是透明的,solid表示边框是实线的*/
border-top-color: black; /*这里我们仅将上边框的颜色设置为黑色,众所周知,css后面的样式代码会覆盖之前的相同的样式代码,至于其他三边的还是透明色*/
/*border-bottom-color: black; //这里设置底部边框色为黑色
border-left-color: black; //这里设置左边边框色为黑色
border-right-color:black //这里设置右边边框色为黑色*/
}
</style><div class="triangle"></div>
则结果为
接下来我们加上 :before
<style>
.test-div{
position: relative; /*日常相对定位*/
width:150px;
height:36px;
border-radius:5px;
border:black 1px solid;
background: rgba(245,1,245,1)
}
.test-div:before{
content: ""; /*:before和:after必带技能,重要性为满5颗星*/
display: block;
position: absolute; /*日常绝对定位*/
top:8px;
width: 0;
height: 0;
border:6px solid transparent;
left:-12px;
border-right-color: rgba(245,1,245,1);
}
</style>
<div class="test-div"></div>
则可看到
通过以上代码,我们将会看到如图所示一个类似对话框的样式,但在对话框四周并不完整,其突出的三角形上没有边框。要怎么修改呢?如下:
<style>
.test-div{
position: relative; /*日常相对定位*/
width:150px;
height: 36px;
border:1px solid black;
border-radius:5px;
background: rgba(245,1,245,1)
}
.test-div:before,.test-div:after{
content: ""; /*:before和:after必带技能,重要性为满5颗星*/
display: block;
position: absolute; /*日常绝对定位*/
top:8px;
width: 0;
height: 0;
border:6px solid transparent;
}
.test-div:before{
left:-11px;
border-right-color: rgba(245,1,245,1);
z-index:1
}
.test-div:after{
left:-12px;
border-right-color: rgba(0,0,0,1);
z-index: 0
}
</style>
<div class="test-div"></div>
则得到图
一个完整的对话框出现了,至于对话框的小三角形方向,改变border的position的位置即可实现。
2.作为内容的半透明背景层。
比如我们的需求是做一个半透明的登录框,如下:
<style>
body{
background: url(img/1.jpg) no-repeat left top /*这里加了个图片背景,用以区分背景的半透明及内容的完全不透明*/
}
.test-div{
position: relative; /*日常相对定位*/
width:300px;
height: 120px;
padding: 20px 10px;
font-weight: bold;
}
.test-div:before{
position: absolute; /*日常绝对定位*/
content: ""; /*:before和:after必带技能,重要性为满5颗星*/
top:0;
left: 0;
width: 100%; /*和内容一样的宽度*/
height: 100%; /*和内容一样的高度*/
background: rgba(255,255,1,.5); /*给定背景黄色,透明度50%*/
z-index:-1 /*日常元素堆叠顺序*/
}
</style>
<!--布局简单写写-->
<div class="test-div">
<table>
<tr>
<td>Name</td>
<td><input placeholder="your name" /></td>
</tr>
<tr>
<td>Password</td>
<td><input placeholder="your password" /></td>
</tr>
<tr>
<td></td>
<td><input type="button" value="login" /></td>
</tr>
</table>
</div>
则可以看到背景图是随便选的,不要在意。
当然, :before和:after也还有其他更多的巧妙用法,这里也不一一列举出来了,这里放上一个用这两个伪元素加上CSS3动画实现一些比较好看及实用的动态效果的连接:HoverEffectIdeas
以下附上弹出框的方法
<style>
.ol-popup {
position: absolute;
background-color: white;
-webkit-filter: drop-shadow(0 1px 4px rgba(0,0,0,0.2));
filter: drop-shadow(0 1px 4px rgba(0,0,0,0.2));
padding: 15px;
border-radius: 10px;
border: 1px solid #cccccc;
bottom: 500px;
left: 500px;
min-width: 280px;
}
.ol-popup:after, .ol-popup:before {
top: 100%;
border: solid transparent;
content: " ";
height: 0;
width: 0;
position: absolute;
pointer-events: none;
}
.ol-popup:after {
border-top-color: white;
border-width: 10px;
left: 48px;
margin-left: -10px;
}
.ol-popup:before {
border-top-color: #cccccc;
border-width: 11px;
left: 48px;
margin-left: -11px;
}
.ol-popup-closer {
text-decoration: none;
position: absolute;
top: 2px;
right: 8px;
}
.ol-popup-closer:after {
content: "✖";
}
</style>
<div id="popup" class="ol-popup">
<a href="#" id="popup-closer" class="ol-popup-closer"></a> <!-- href="#"是指联接到当前页面 -->
<div id="popup-content"></div>
</div>