不可以不知道道的CSS挑选器技能

2021-03-04 12:35 jianzhan

CSS挑选器技能共享给大伙儿,供大伙儿参照,实际內容以下

甚么是:before和:after? 该怎样应用她们?

:before是css中的1种伪元素,能用于在某个元素以前插进一些內容。
:after是css中的1种伪元素,能用于在某个元素以后插进一些內容。

下面大家先跑个简易的编码检测下实际效果:

CSS Code拷贝內容到剪贴板
  1. <style>   
  2.   
  3.   p:before{   
  4.   
  5.       content"H"  /*:before和:after必带专业技能,关键性为满5颗星*/  
  6.   
  7.   }   
  8.   
  9.   p:after{   
  10.   
  11.       content"d"  /*:before和:after必带专业技能,关键性为满5颗星*/  
  12.   
  13.   }   
  14.   
  15. </style>   
  16.   
  17. <p>ello Worl</p>   

 以上的编码可能在网页页面中呈现的是"Hello World"。大家根据访问器的"核查元素"看到的內容是:

XML/HTML Code拷贝內容到剪贴板
  1. <p>  
  2.   
  3.   ::before   
  4.   
  5.   "ello Worl"   
  6.   
  7.   ::after</p>  
  8.   

p标识內部的內容的前面会被插进1个:before伪元素,该伪元素内包括的內容是"H";而在p标识内的內容后边会被插进1个:after伪元素,该元素包括的內容是"d"。做为1只达标的程序流程小猴子,保卫"Hello World"的详细存在是必要的。


既然笔记关键对于是:before和:after,那末毫无疑问不容易只是仅唯一以上的简易详细介绍就完事。下面大家看看平时该如何应用她们。

1.融合border写个会话框的款式

本兽将上面这句话拆成2一部分:融合border,写个会话框的款式。
既然是融合border,那末大家先转个小话题,简易循序渐进的详细介绍下如何用border画3角形款式(这个3角形在写会话框款式的情况下必须):

CSS Code拷贝內容到剪贴板
  1. <style>   
  2.   
  3.    .triangle{   
  4.   
  5.        width: 0;   
  6.   
  7.        height: 0;   
  8.   
  9.        border-left:50px solid red;   
  10.   
  11.        border-bottom:50px solid blue;   
  12.   
  13.        border-top:50px solid black;   
  14.   
  15.        border-right:50px solid purple    }   
  16.   
  17.  </style>   
  18.   
  19.  <div class="triangle"></div>   

以上编码可能在网页页面上展现1个正方形,左侧是个鲜红色的3角形,右侧是紫色的3角形,上面是黑色的3角形,下面是蓝色的3角形。那末有人就会问,大家要的并不是3角形么?野兽你画个正方形逗我呢?
大家对上面的款式做些改动:

CSS Code拷贝內容到剪贴板
  1. .triangle{   
  2.   
  3.     width: 0;   
  4.   
  5.     height: 0;   
  6.   
  7.     border:50px transparent solid/*这里大家将元素的边框宽度设定为50px,transparent表明边框色调是全透明的,solid表明边框是实线的*/  
  8.   
  9.     border-top-colorblack;  /*这里大家仅将上边框的色调设定为黑色,大家都知道,css后边的款式编码会遮盖以前的同样的款式编码,至于别的3边的還是全透明色*/  
  10.   
  11.     /*border-bottom-color: black; /*这里设定底部边框色为黑色*/  
  12.   
  13.     border-left-colorblack;  /*这里设定左侧边框色为黑色*/  
  14.   
  15.     border-right-color:black*/ /*这里设定右侧边框色为黑色*/  
  16.   
  17. }    

随后这时候大家就会看到1个在顶部的方位向下的3角形。解释已详尽的写在css款式的注解里。

接下来大家再加:before:

CSS Code拷贝內容到剪贴板
  1. <style>   
  2.   
  3.   .test-div{   
  4.   
  5.       positionrelative;  /*平常相对性精准定位*/  
  6.   
  7.       width:150px;   
  8.   
  9.       height:36px;   
  10.   
  11.       border-radius:5px;   
  12.   
  13.       border:black 1px solid;   
  14.   
  15.       background: rgba(245,245,245,1)    }   
  16.   
  17.   .test-div:before{   
  18.   
  19.       content"";  /*:before和:after必带专业技能,关键性为满5颗星*/  
  20.   
  21.       displayblock;   
  22.   
  23.       positionabsolute;  /*平常肯定精准定位*/  
  24.   
  25.       top:8px;   
  26.   
  27.       width: 0;   
  28.   
  29.       height: 0;   
  30.   
  31.       border:6px transparent solid;   
  32.   
  33.       left:-12px;   
  34.   
  35.       border-right-color: rgba(245,245,245,1);   
  36.   
  37.   }   
  38.   
  39. </style>   
  40.   
  41. <div class="test-div"></div>   

 根据以上编码,大家可能看见1个相近手机微信/QQ的会话框款式,可是不完美的是,在会话框的4周的边框并不是详细的,而是在会话框的突显3角形上是木有边框的T_T一瞬间冷场有没有,应该怎么办呢?让招唤:after衣着棉大衣来救场吧~
详细编码: 

CSS Code拷贝內容到剪贴板
  1. <style>   
  2.   
  3.   .test-div{   
  4.   
  5.       positionrelative;  /*平常相对性精准定位*/  
  6.   
  7.       width:150px;   
  8.   
  9.       height36px;   
  10.   
  11.       border:black 1px solid;   
  12.   
  13.       border-radius:5px;   
  14.   
  15.       background: rgba(245,245,245,1)    }   
  16.   
  17.   .test-div:before,.test-div:after{   
  18.   
  19.       content"";  /*:before和:after必带专业技能,关键性为满5颗星*/  
  20.   
  21.       displayblock;   
  22.   
  23.       positionabsolute;  /*平常肯定精准定位*/  
  24.   
  25.       top:8px;   
  26.   
  27.       width: 0;   
  28.   
  29.       height: 0;   
  30.   
  31.       border:6px transparent solid;   
  32.   
  33.   }   
  34.   
  35.   .test-div:before{   
  36.   
  37.       left:-11px;   
  38.   
  39.       border-right-color: rgba(245,245,245,1);   
  40.   
  41.       z-index:1    }   
  42.   
  43.   .test-div:after{   
  44.   
  45.       left:-12px;   
  46.   
  47.       border-right-color: rgba(0,0,0,1);   
  48.   
  49.       z-index: 0    }   
  50.   
  51. </style>   
  52.   
  53. <div class="test-div"></div>   

 好了,详细的1个会话框款式展现在眼下了,至于会话框的小3角形的方位,坚信大伙儿看了上上段针对border详细介绍的编码也都了解该如何做了吧,没错,便是改下position的部位,改下border显示信息色调的方向~ (本兽不喜爱贴照片,迁就下额,必须的能够复制编码立即运作看实际效果,造轮子不仅是造轮子,也能令人加深印象,更好的了解)

2.做为內容的半全透明情况层

例如大家的要求是做1个半全透明的登陆框吧(这里也是在编码中根据注解来解释):

XML/HTML Code拷贝內容到剪贴板
  1. <style>  
  2.   
  3.     body{   
  4.   
  5.         background: url(img/1.jpg) no-repeat left top /*这里本兽加了个照片情况,用以区别情况的半全透明及內容的彻底不全透明*/   
  6.   
  7.     }   
  8.   
  9.     .test-div{   
  10.   
  11.         position: relative;  /*平常相对性精准定位(关键,下面內容也会详细介绍)*/   
  12.   
  13.         width:300px;   
  14.   
  15.         height: 120px;   
  16.   
  17.         padding: 20px 10px;   
  18.   
  19.         font-weight: bold;   
  20.   
  21.     }   
  22.   
  23.     .test-div:before{   
  24.   
  25.         position: absolute;  /*平常肯定精准定位(关键,下面內容也会略带详细介绍)*/   
  26.   
  27.         content: "";  /*:before和:after必带专业技能,关键性为满5颗星*/   
  28.   
  29.         top:0;   
  30.   
  31.         left: 0;   
  32.   
  33.         width: 100%;  /*和內容1样的宽度*/   
  34.   
  35.         height: 100%;  /*和內容1样的高宽比*/   
  36.   
  37.         background: rgba(255,255,255,.5); /*给定情况白色,全透明度50%*/   
  38.   
  39.         z-index:⑴ /*平常元素层叠次序(关键,下面內容也会略带详细介绍)*/   
  40.   
  41.     }   
  42.   
  43. </style>  
  44.   
  45. <!--这里容兽偷个懒,合理布局简易写写-->  
  46.   
  47. <div class="test-div">  
  48.   
  49.     <table>  
  50.   
  51.         <tr>  
  52.   
  53.             <td>Name</td>  
  54.   
  55.             <td><input placeholder="your name" /></td>  
  56.   
  57.         </tr>  
  58.   
  59.         <tr>  
  60.   
  61.             <td>Password</td>  
  62.   
  63.             <td><input placeholder="your password" /></td>  
  64.   
  65.         </tr>  
  66.   
  67.         <tr>  
  68.   
  69.             <td></td>  
  70.   
  71.             <td><input type="button" value="login" /></td>  
  72.   
  73.         </tr>  
  74.   
  75.     </table>  
  76.   
  77. </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拷贝內容到剪贴板
  1. <!--position:absolute-->   
  2.   
  3.   <style>   
  4.   
  5.       body{   
  6.   
  7.           height2000px  /*这里将body的高宽比设定为2000px是以便区别absolute和fixed的区别*/  
  8.   
  9.       }   
  10.   
  11.       .test-div{   
  12.   
  13.           position:absolute;   
  14.   
  15.           left:50px;   
  16.   
  17.           top:50px      }   
  18.   
  19.   </style>   
  20.   
  21.   <div class="test-div">Hello World</div><!--position:fixed-->   
  22.   
  23.   <style>   
  24.   
  25.       body{   
  26.   
  27.           height2000px  /*这里将body的高宽比设定为2000px是以便区别absolute和fixed的区别*/  
  28.   
  29.       }   
  30.   
  31.       .test-div{   
  32.   
  33.           position:fixed;   
  34.   
  35.           left:50px;   
  36.   
  37.           top:50px      }   
  38.   
  39.   </style>   
  40.   
  41.   <div class="test-div">Hello World</div><!--position:relative + position:absolute-->   
  42.   
  43.   <style>   
  44.   
  45.       .out-div{   
  46.   
  47.           width300px;   
  48.   
  49.           height300px;   
  50.   
  51.           backgroundpurple;  /*这里界定个情况,让大家了解这个div在哪儿*/  
  52.   
  53.           margin:50px 0px 0px 50px;   
  54.   
  55.           positionrelative      }   
  56.   
  57.       .in-div{   
  58.   
  59.           position:absolute;   
  60.   
  61.           left:50px;   
  62.   
  63.           top:50px      }   
  64.   
  65.   </style>   
  66.   
  67.   <div class="out-div">   
  68.   
  69.       <div class="in-div">Hello World</div>   
  70.   
  71.   </div>   
  72.    

z-index 元素层叠排列

z-index用于设定或查找目标的层叠次序,对应的脚本制作特点为zIndex。
z-index的标值越大,该元素的层叠等级越高。

编码: 

CSS Code拷贝內容到剪贴板
  1. <style>   
  2.   
  3.     .first-div{   
  4.   
  5.         width300px;   
  6.   
  7.         height300px;   
  8.   
  9.         backgroundpurple;  /*这里界定个情况,让大家了解这个div在哪儿*/  
  10.   
  11.         positionabsolute;   
  12.   
  13.         left:50px;   
  14.   
  15.         top:50px;   
  16.   
  17.         z-index: 1      }   
  18.   
  19.     .second-div{   
  20.   
  21.         position:absolute;   
  22.   
  23.         left:80px;   
  24.   
  25.         top:80px;   
  26.   
  27.         width:50px;   
  28.   
  29.         height50px;   
  30.   
  31.         backgroundwhite;   
  32.   
  33.         z-index: 2      }   
  34.   
  35. </style>   
  36.   
  37. <div class="first-div"></div>   
  38.   
  39. <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拷贝內容到剪贴板
  1. <style>   
  2.   
  3.     div{   
  4.   
  5.         width100px;   
  6.   
  7.         height100px;   
  8.   
  9.         floatleft      }   
  10.   
  11.     .first-div{   
  12.   
  13.         backgroundpurple;   
  14.   
  15.         zoom:1.5      }   
  16.   
  17.     .second-div{   
  18.   
  19.         backgroundblack;   
  20.   
  21.         zoom:1      }   
  22.   
  23.     .third-div{   
  24.   
  25.         backgroundred;   
  26.   
  27.         zoom:.5      }   
  28.   
  29. </style>   
  30.   
  31. <div class="first-div"></div>   
  32.   
  33. <div class="second-div"></div>   
  34.   
  35. <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拷贝內容到剪贴板
  1. <style>   
  2.   
  3.      body{   
  4.   
  5.        font-size12px;     
  6.   
  7.      }   
  8.   
  9.      /*html{  
  10.  
  11.          font-size: 12px;  
  12.  
  13.      }*/  
  14.   
  15.      div{   
  16.   
  17.          width200px;   
  18.   
  19.          height100px;   
  20.   
  21.          float:left      }   
  22.   
  23.      .first-div{   
  24.   
  25.          font-size: 1em      }   
  26.   
  27.      .second-div{   
  28.   
  29.          font-size: 2em      }   
  30.   
  31.      .third-div{   
  32.   
  33.          font-size: 1rem      }   
  34.   
  35.      .fourth-div{   
  36.   
  37.          font-size: 2rem      }   
  38.   
  39.  </style>   
  40.   
  41.  <div class="first-div">Hello World</div>   
  42.   
  43.  <div class="second-div">Hello World</div>   
  44.   
  45.  <div class="third-div">Hello World</div>   
  46.   
  47.  <div class="fourth-div">Hello World</div>   

 以上编码各自展现了不一样尺寸的字体样式,em和rem的差别能够根据仅仅注解body字体样式款式和html字体样式款式看来看她们之间的区别。

原文:http://www.cnblogs.com/cwjie/p/5257963.html