CSS挑选器技能共享给大伙儿,供大伙儿参照,实际內容以下
甚么是:before和:after? 该怎样应用她们?
:before是css中的1种伪元素,能用于在某个元素以前插进一些內容。
:after是css中的1种伪元素,能用于在某个元素以后插进一些內容。
下面大家先跑个简易的编码检测下实际效果:
CSS Code拷贝內容到剪贴板
- <style>
-
- p:before{
-
- content: "H"
-
- }
-
- p:after{
-
- content: "d"
-
- }
-
- </style>
-
- <p>ello Worl</p>
以上的编码可能在网页页面中呈现的是"Hello World"。大家根据访问器的"核查元素"看到的內容是:
XML/HTML Code拷贝內容到剪贴板
- <p>
-
- ::before
-
- "ello Worl"
-
- ::after</p>
-
p标识內部的內容的前面会被插进1个:before伪元素,该伪元素内包括的內容是"H";而在p标识内的內容后边会被插进1个:after伪元素,该元素包括的內容是"d"。做为1只达标的程序流程小猴子,保卫"Hello World"的详细存在是必要的。
既然笔记关键对于是:before和:after,那末毫无疑问不容易只是仅唯一以上的简易详细介绍就完事。下面大家看看平时该如何应用她们。
1.融合border写个会话框的款式
本兽将上面这句话拆成2一部分:融合border,写个会话框的款式。
既然是融合border,那末大家先转个小话题,简易循序渐进的详细介绍下如何用border画3角形款式(这个3角形在写会话框款式的情况下必须):
CSS Code拷贝內容到剪贴板
- <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>
以上编码可能在网页页面上展现1个正方形,左侧是个鲜红色的3角形,右侧是紫色的3角形,上面是黑色的3角形,下面是蓝色的3角形。那末有人就会问,大家要的并不是3角形么?野兽你画个正方形逗我呢?
大家对上面的款式做些改动:
CSS Code拷贝內容到剪贴板
- .triangle{
-
- width: 0;
-
- height: 0;
-
- border:50px transparent solid;
-
- border-top-color: black;
-
-
-
- border-left-color: black;
-
- border-right-color:black*/
-
- }
随后这时候大家就会看到1个在顶部的方位向下的3角形。解释已详尽的写在css款式的注解里。
接下来大家再加:before:
CSS Code拷贝內容到剪贴板
- <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: "";
-
- 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>
根据以上编码,大家可能看见1个相近手机微信/QQ的会话框款式,可是不完美的是,在会话框的4周的边框并不是详细的,而是在会话框的突显3角形上是木有边框的T_T一瞬间冷场有没有,应该怎么办呢?让招唤:after衣着棉大衣来救场吧~
详细编码:
CSS Code拷贝內容到剪贴板
- <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: "";
-
- 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>
好了,详细的1个会话框款式展现在眼下了,至于会话框的小3角形的方位,坚信大伙儿看了上上段针对border详细介绍的编码也都了解该如何做了吧,没错,便是改下position的部位,改下border显示信息色调的方向~ (本兽不喜爱贴照片,迁就下额,必须的能够复制编码立即运作看实际效果,造轮子不仅是造轮子,也能令人加深印象,更好的了解)
2.做为內容的半全透明情况层
例如大家的要求是做1个半全透明的登陆框吧(这里也是在编码中根据注解来解释):
XML/HTML Code拷贝內容到剪贴板
- <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%; /*和內容1样的宽度*/
-
- height: 100%; /*和內容1样的高宽比*/
-
- background: rgba(255,255,255,.5); /*给定情况白色,全透明度50%*/
-
- z-index:⑴ /*平常元素层叠次序(关键,下面內容也会略带详细介绍)*/
-
- }
-
- </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也也有别的更多的恰当用法,这里也不11列出来了,这里放上1个用这两个伪元素再加css3动漫完成1些较为漂亮及好用的动态性实际效果的连接:HoverEffectIdeas
说完了:before和:after,大家略微扯扯1些别的的css款式及合理布局留意点(将会大伙儿不如何留意,从而致使1些合理布局和款式出难题)。
position 精准定位的难题
position特性要求了元素的精准定位种类,默认设置为static。
该特性还能够有下值:
absolute:转化成肯定精准定位的元素,相对 static 精准定位之外的第1个父元素开展精准定位。
fixed:转化成肯定精准定位的元素,相对访问器对话框开展精准定位。
relative:转化成相对性精准定位的元素,相对其一切正常部位开展精准定位。
inherit:要求应当从父元素承继 position 特性的值。
编码:
CSS Code拷贝內容到剪贴板
- <!--position:absolute-->
-
- <style>
-
- body{
-
- height: 2000px
-
- }
-
- .test-div{
-
- position:absolute;
-
- left:50px;
-
- top:50px }
-
- </style>
-
- <div class="test-div">Hello World</div><!--position:fixed-->
-
- <style>
-
- body{
-
- height: 2000px
-
- }
-
- .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;
-
- 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的标值越大,该元素的层叠等级越高。
编码:
CSS Code拷贝內容到剪贴板
- <style>
-
- .first-div{
-
- width: 300px;
-
- height: 300px;
-
- background: purple;
-
- 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>
这里大家将第1个div和第2个div部位放到1起,便捷看z-index的实际效果。以上编码的款式是紫色的正方形里边有个白色的小正方形。由于小正方形的z-index超过大正方形的z-index,因此能显示信息出,当大家把.first-div的z-index设定为3,这时候候就看不见白色的小正方形了,它被紫色的大正方形无情的挡掉了..
zoom 元素放缩占比
zoom可用于全部元素,用于设定或查找目标的放缩占比,对应的脚本制作特点为zoom,原占比的值是1。
CSS Code拷贝內容到剪贴板
- <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尺寸,內部子元素会承继这1特性的款式。
rem = root em 。说白了,root即根部的,顶部的。也便是根部的em,这个根部指的是HTML根元素。因此rem的尺寸是对于HTML根元素的尺寸做字体样式的相对性尺寸的调剂。
CSS Code拷贝內容到剪贴板
- <style>
-
- body{
-
- 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字体样式款式看来看她们之间的区别。
原文:http://www.cnblogs.com/cwjie/p/5257963.html