你应该知道CSS选择器技巧
什么是: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"。作为一只合格的程序猴子,捍卫"Hello
World"的完整存在是必要的。
既然笔记主要针对是:before和:after,那么肯定不会只是仅仅有以上的简单介绍就完事。下面我们看看平常该怎么使用他们。
1.结合border写个对话框的样式。
本兽将上面这句话拆成2部分:结合border,写个对话框的样式。
既然是结合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>
以上代码将会在页面上展示一个正方形,左边是个红色的三角形,右边是紫色的三角形,上面是黑色的三角形,下面是蓝色的三角形。那么有人就会问,我们要的不是三角形么?野兽你画个正方形逗我呢?
我们对上面的样式做些修改:
.triangle{
width: 0;
height: 0;
border:50px transparent
solid; /*这里我们将元素的边框宽度设置为50px,transparent表示边框颜色是透明的,solid表示边框是实线的*/
border-top-color: black;
/*这里我们仅将上边框的颜色设置为黑色,众所周知,css后面的样式代码会覆盖之前的相同的样式代码,至于其他三边的还是透明色*/
/*border-bottom-color:
black; /*这里设置底部边框色为黑色*/
border-left-color: black;
/*这里设置左边边框色为黑色*/
border-right-color:black*/
/*这里设置右边边框色为黑色*/
}
然后这时我们就会看到一个在顶部的方向向下的三角形。解释已详细的写在css样式的注释里。
接下来我们加上:before:
<style>
.test-div{
position: relative;
/*日常相对定位*/
width:150px;
height:36px;
border-radius:5px;
border:black 1px
solid;
background:
rgba(245,245,245,1) }
.test-div:before{
content:
""; /*:before和:after必带技能,重要性为满5颗星*/
display: block;
position: absolute;
/*日常绝对定位*/
top:8px;
width: 0;
height: 0;
border:6px
transparent solid;
left:-12px;
border-right-color:
rgba(245,245,245,1);
}
</style>
<div
class="test-div"></div>
通过以上代码,我们将会看见一个类似微信/QQ的对话框样式,但是美中不足的是,在对话框的四周的边框不是完整的,而是在对话框的突出三角形上是木有边框的T_T瞬间冷场有木有,该怎么办呢?让召唤:after穿着棉大衣来救场吧~
完整代码:
<style>
.test-div{
position: relative;
/*日常相对定位*/
width:150px;
height: 36px;
border:black 1px
solid;
border-radius:5px;
background:
rgba(245,245,245,1) }
.test-div:before,.test-div:after{
content:
""; /*:before和:after必带技能,重要性为满5颗星*/
display: block;
position: absolute;
/*日常绝对定位*/
top:8px;
width: 0;
height: 0;
border:6px
transparent solid;
}
.test-div:before{
left:-11px;
border-right-color:
rgba(245,245,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的位置,改下border显示颜色的方位~ (本兽不喜欢贴图片,体谅下额,需要的可以拷贝代码直接运行看效果,造轮子不仅仅是造轮子,也能让人加深印象,更好的理解)
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,255,.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>
上面的代码拷贝过去,加上张图片可测试效果。
当然,:bofore和:after也还有其他更多的巧妙用法,这里也不一一列出来了,这里放上一个用这两个伪元素加上css3动画实现一些比较好看及实用的动态效果的链接:HoverEffectIdeas
说完了:before和:after,我们稍微扯扯一些其他的css样式及布局注意点(可能大家不怎么注意,从而导致一些布局和样式出问题)。
position 定位的问题
position属性规定了元素的定位类型,默认为static。
该属性还可以有下值:
absolute:生成绝对定位的元素,相对于 static 定位以外的第一个父元素进行定位。
fixed:生成绝对定位的元素,相对于浏览器窗口进行定位。
relative:生成相对定位的元素,相对于其正常位置进行定位。
inherit:规定应该从父元素继承 position 属性的值。
代码:
<!--position:absolute-->
<style>
body{
height:
2000px /*这里将body的高度设置为2000px是为了区分absolute和fixed的差别*/
}
.test-div{
position:absolute;
left:50px;
top:50px
}
</style>
<div
class="test-div">Hello
World</div><!--position:fixed-->
<style>
body{
height:
2000px /*这里将body的高度设置为2000px是为了区分absolute和fixed的差别*/
}
.test-div{
position:fixed;
left:50px;
top:50px
}
</style>
<div
class="test-div">Hello World</div><!--position:relative +
position:absolute-->
<style>
.out-div{
width:
300px;
height:
300px;
background: purple; /*这里定义个背景,让我们知道这个div在哪*/
margin:50px
0px 0px 50px;
position:
relative }
.in-div{
position:absolute;
left:50px;
top:50px
}
</style>
<div class="out-div">
<div
class="in-div">Hello World</div>
</div>
z-index 元素堆叠排序
z-index用于设置或检索对象的堆叠顺序,对应的脚本特性为zIndex。
z-index的数值越大,该元素的堆叠层级越高。
代码:
<style>
.first-div{
width:
300px;
height:
300px;
background:
purple; /*这里定义个背景,让我们知道这个div在哪*/
position:
absolute;
left:50px;
top:50px;
z-index: 1
}
.second-div{
position:absolute;
left:80px;
top:80px;
width:50px;
height:
50px;
background: white;
z-index: 2
}
</style>
<div
class="first-div"></div>
<div
class="second-div"></div>
这里我们将第一个div和第二个div位置放到一起,方便看z-index的效果。以上代码的样式是紫色的正方形里面有个白色的小正方形。因为小正方形的z-index大于大正方形的z-index,所以能显示出,当我们把.first-div的z-index设置为3,这时候就看不到白色的小正方形了,它被紫色的大正方形无情的挡掉了..
zoom 元素缩放比例
zoom适用于所有元素,用于设置或检索对象的缩放比例,对应的脚本特性为zoom,原比例的值是1。
<style>
div{
width:
100px;
height:
100px;
float: left
}
.first-div{
background:
purple;
zoom:1.5
}
.second-div{
background:
black;
zoom:1
}
.third-div{
background:
red;
zoom:.5
}
</style>
<div
class="first-div"></div>
<div
class="second-div"></div>
<div
class="third-div"></div>
以上代码将会展示的依次是紫色-黑色-红色的div,大小分别是100px的1.5倍,1倍,0.5倍。
em 和 rem 是什么
1em等于当前的字体尺寸,数值的改变意味着字体大小的调整。em 有继承这个特性,也就是说,外部父元素定义了字体的em大小,内部子元素会继承这一属性的样式。
rem = root em 。顾名思义,root即根部的,顶部的。也就是根部的em,这个根部指的是HTML根元素。所以rem的大小是针对HTML根元素的大小做字体的相对大小的调整。
<style>
body{
font-size: 12px;
}
/*html{
font-size:
12px;
}*/
div{
width:
200px;
height:
100px;
float:left
}
.first-div{
font-size: 1em }
.second-div{
font-size:
2em }
.third-div{
font-size:
1rem }
.fourth-div{
font-size:
2rem }
</style>
<div
class="first-div">Hello World</div>
<div
class="second-div">Hello World</div>
<div
class="third-div">Hello World</div>
<div
class="fourth-div">Hello World</div>
以上代码分别展示了不同大小的字体,em和rem的区别可以通过仅仅注释body字体样式和html字体样式来看看他们之间的差别。
你应该知道CSS选择器技巧的更多相关文章
- 【CSS】381- 提升你的CSS选择器技巧
我已经使用CSS多年了,但直到最近我才深入研究了一下CSS选择器. 我为什么要这样做呢?我们都知道选择器,但麻烦的是随着时间的推移,很容易习惯于在每个项目中使用相同的可信任选择器来实现你需要做的事情. ...
- 前端极易被误导的css选择器权重计算及css内联样式的妙用技巧
记得大学时候,专业课的网页设计书籍里面讲过css选择器权重的计算:id是100,class是10,html标签是5等等,然后全部加起来的和进行比较... 我只想说:真是误人子弟,害人不浅! 最近,在前 ...
- css选择器顺序的小技巧
在线演示 本地下载 css的选择器的顺序其实很有意思,如果应用的好的话,可以做一些简单的逻辑出来,配合上css3,就可以尽可能的脱离js了. 这里的演示是一个带有hover事件的四张照片,效果来自一个 ...
- 你所不知道的 CSS 阴影技巧与细节 滚动视差?CSS 不在话下 神奇的选择器 :focus-within 当角色转换为面试官之后 NPOI 教程 - 3.2 打印相关设置 前端XSS相关整理 委托入门案例
你所不知道的 CSS 阴影技巧与细节 关于 CSS 阴影,之前已经有写过一篇,box-shadow 与 filter:drop-shadow 详解及奇技淫巧,介绍了一些关于 box-shadow ...
- CSS 代码技巧与维护 ★ Mozilla Hacks – the Web developer blog
原文链接:https://hacks.mozilla.org/2016/05/css-coding-techniques/ 译文链接 :http://www.zcfy.cc/article/css-c ...
- 总结30个CSS选择器
或许大家平时总是在用的选择器都是:#id .class 以及标签选择器.可是这些还远远不够,为了在开发中更加得心应手,本文总结了30个CSS3选择器,希望对大家有所帮助. 1 *:通用选择器 * ...
- CSS选择器以及优先级与匹配原理
最常用的五类CSS选择器 准确而简洁的运用CSS选择器会达到非常好的效果.我们不必通篇给每一个元素定义类(class)或ID,通过合适的组织,可以用最简单的方法实现同样的效果.在实际工作中,最常用的选 ...
- 前端开发者应该知道的 CSS 小技巧
一些小技巧让你的CSS技术更专业 使用:not()去除导航上不需要的边框 为body添加行高 垂直居中任何元素 逗号分离的列表 使用负nth-child选择元素 使用SVG图标 文本显示优化 在纯CS ...
- 2天驾驭DIV+CSS (技巧篇)(转)
这是去年看到的一片文章,感觉在我的学习中,有不少的影响.于是把它分享给想很快了解css的兄弟们.本文是技巧篇. 基础篇[知识一] “DIV+CSS” 的叫法是不准确的[知识二] “DIV+CSS” ...
随机推荐
- iOS 的 APP 如何适应 iPhone 5s/6/6Plus 三种屏幕的尺寸?(转)
原文:http://www.niaogebiji.com/article-4379-1.html?utm_source=tuicool 初代iPhone 2007年,初代iPhone发布,屏幕的宽高是 ...
- 产品专家Marty Cagan:不做仅仅会编码的人
Marty Cagan是享有世界声誉的产品管理专家,曾担任Netscape副总裁.eBay产品管理及设计高级副总裁. 近日,记者在"PM-China首届产品经理高峰论坛"上对他做了 ...
- Service的基本组成
Service与Activity的最大区别就是一有界面,一个没有界面. 如果某些程序操作很消耗时间,那么可以将这些程序定义在Service之中,这样就可以完成程序的后台运行, 其实Service就是一 ...
- Setup Factory
Setup Factory 生成安装程序
- html系列教程--article audio
<article> 标签 <article> 标签规定独立的自包含内容.一篇文章应有其自身的意义,应该有可能独立于站点的其余部分对其进行分发. <article> ...
- Response.Redirec方法传递汉字出现乱码
解决方法: //传参数时Response.Redirect("a.aspx?name"+Server.UrlEncode("我的名字")); //接收参数时 S ...
- Fedora 20忘记root密码
1.忘记root密码的情况下.用sudo账户$sudo su就行了. 2.直接sudo passwd root就重置了roor密码了.
- 《C++ Primer Plus 6th》读书笔记 - 第8章 函数探幽
1. 摘录 默认参数指的是当函数调用中省略了实参时自动使用的一个值. 默认参数并非编程方面的重大突破,而只是提供了一种便捷的方式.使用默认参数,可以减少要定义的析构函数.方法以及方法重载的数量. 试图 ...
- codeforces 21D. Traveling Graph 状压dp
题目链接 题目大意: 给一个无向图, n个点m条边, 每条边有权值, 问你从1出发, 每条边至少走一次, 最终回到点1. 所走的距离最短是多少. 如果这个图是一个欧拉回路, 即所有点的度数为偶数. 那 ...
- C#access数据库操作
比较凌乱,有时间在整理吧. Provider=Microsoft.Jet.OLEDB.!" private void GetCon() { string strConnection=&quo ...