zoukankan      html  css  js  c++  java
  • CSS选择器

    CSS选择器

    一、css选择器的分类

     

    二、选择器的语法

      

    1,基本选择器语法

    选择器 类型 功能描述 示例
    *  通配选择器  选择文档中所有HTML元素  
    E  元素选择器 选择指定类型的HTML元素

    <div></div>

    div{

      background-color:red;

    }

    #id  ID选择器 选择指定ID属性值为“id”的任意类型元素

    <div id="container"></div>

    #container{

      background-color:red;

    }

    .class  类选择器 选择指定class属性值为“class”的任意类型的任意多个元素

    <div class="container"></div>

    .container{

      background-color:red;

    }

    selector1,selectorN  群组选择器 将每一个选择器匹配的元素集合并

    <div class="container"></div>

    <div class="container1"></div>

    .container,.container{

      background-color:red;

    }

    2,层次选择器语法

    选择器 类型 功能描述 示例
    E  F 后代选择器(包含选择器) 选择匹配的F元素,且匹配的F元素被包含在匹配的E元素内

    <div cass="parent">

      <div class="child">

        <div class="child"></div>

      </div>

    </div>

    .parent .child{

      /*包含了parent下的所有child*/

    }

    E>F 子选择器 选择匹配的F元素,且匹配的F元素所匹配的E元素的子元素  

    <div cass="parent">

      <div class="child">

        <div class="child"></div>

      </div>

    </div>

    .parent>.child{

      /*只包含了parent下的直接子元素第一层child,

    如果child元素不是紧挨着parent,那么是无效的*/

    }

    E+F 相邻兄弟选择器 选择匹配的F元素,且匹配的F元素紧位于匹配的E元素的后面  

    <div class="container"></div>

    <div>第一个兄弟</div>

    <div>第二个兄弟</div>

    .container+div{

      /*只包含了第一个兄弟,第二个兄弟不会匹配到*/

    }

    E~F 通用选择器 选择匹配的F元素,且位于匹配的E元素后的所有匹配的同层F元素  
    <div class="ele"></div>
    <div class="ele1">ele1边框会变红
    <div class="ele2">ele2边框不变</div>
    </div>
    .ele1,.ele2{
    border: 1px solid #000;
    }
    .ele~div{
    border: 1px solid red;
    20px;
    height: 20px;
    padding: 10px;
    }
    .ele2{
    10px;
    height: 10px;
    }

    3,动态伪类选择器语法

    选择器 类型 功能描述
    E:link 链接伪类选择器   选择匹配的E元素,而且匹配元素被定义了超链接并未被访问过。常用于链接描点上
    E:visited   链接伪类选择器 选择匹配的E元素,而且匹配元素被定义了超链接并已被访问过。常用于链接描点上
    E:active 用户行为选择器 选择匹配的E元素,且匹配元素被激活。常用于链接描点和按钮上
    E:hover 用户行为选择器 选择匹配的E元素,且用户鼠标停留在元素E上。IE6及以下浏览器仅支持a:hover
    E:focus 用户行为选择器 选择匹配的E元素,而且匹配元素获取焦点

    4,目标伪类选择器

    选择器 功能描述
    E:target 选择匹配E的所有元素,且匹配元素被相关URL指向

    5,UI元素状态伪类选择器语法

    选择器 类型 功能描述
    E:checked 选中状态伪类选择器 匹配选中的复选按钮或者单选按钮表单元素
    E:enabled 启用状态伪类选择器 匹配所有启用的表单元素
    E:disabled 不可用状态伪类选择器 匹配所有禁用的表单元素

     6,结构伪类选择器使用语法

    选择器 功能描述 示例
    E:first-child 作为父元素的第一个子元素的元素E。与E:nth-child(1)等同
    <div class="parent">
    <div>第一个div元素</div>
    <div>第二个div元素</div>
    </div>
    .parent div:first-child{
    background-color: red;
    }
    /*此时第一个div元素会变红,如果第一个div元素前面再加一个其他元素,
    如:P,则不会变红,因为此时他不属于其父元素的第一个div元素*/
    E:last-child 作为父元素的最后一个子元素的元素E。与E:nth-last-child(1)等同
    <div class="parent">
    <div>第一个div元素</div>
    <div>第二个div元素</div>
    </div>
    .parent div:last-child{
        background-color: red;
    }
    /*此时第二个div元素即最后一个会变红,如果最后一个div元素后面再加一个其他元素,
    如:P,则不会变红,因为此时他不属于其父元素的最后一个div元素*/
    E:root

    选择匹配元素E所在文档的根元素。在HTML文档中,根元素始终是html,

    此时该选择器与html类型选择器匹配的内容相同

     
    E F:nth-child(n)

    选择父元素E的第n个子元素F。其中n可以是整数(1,2,3)、关键字(even,odd)、

    可以是公式(2n+1),而且n值起始值为1,而不是0.

     
    <div class="parent">
    <div>第一个div元素</div>
    <div>第二个div元素</div>
    </div>
    .parent div:nth-child(1){
    background-color: red;
    }
    /*此时第一个div元素会变红,如果第一个div元素前面再加一个其他元素,
    如:P,则不会变红,因为此时他不属于其父元素的第一个div元素*/
    E F:nth-last-child(n)

    选择父元素E的倒数第n个子元素F。此选择器与E:nth-child(n)选择器计算顺序刚好相反,

    但使用方法都是一样的,其中:nth-last-child(1)始终匹配最后一个元素,与last-child等同

     
    <div class="parent">
    <div>第一个div元素</div>
    <div>第二个div元素</div>
    </div>
    .parent div:nth-last-child(1){
        background-color: red;
    }
    /*此时第二个div元素即最后一个会变红,如果最后一个div元素后面再加一个其他元素,
    如:P,则不会变红,因为此时他不属于其父元素的最后一个div元素*/
    E:nth-of-type(n) 选择父元素内具有指定类型的第n个E元素  
    <div class="parent">
       <p></p>
    <div>第一个div元素</div>
    <div>第二个div元素</div>
    </div>
    .parent div:nth-of-type(1){
    background-color: red;
    }
    /*此时第一个div元素会变红,这就是与nth-child所区别的,只识别同类型的div元素*/
    E:nth-last-of-type(n) 选择父元素内具有指定类型的倒数第n个E元素  
    <div class="parent">
    <div>第一个div元素</div>
    <div>第二个div元素</div>
      <p></p>
    </div>
    .parent div:nth-of-type(1){
    background-color: red;
    }
    /*此时第二个div元素会变红,这就是与nth-last-child所区别的,只识别同类型的div元素*/
    E:first-of-type 选择父元素内具有指定类型的第一个E元素,与E:nth-of-type(1)等同  
    <div class="parent">
       <p></p>
    <div>第一个div元素</div>
    <div>第二个div元素</div>
    </div>
    .parent div:nth-of-type(1){
    background-color: red;
    }
    /*此时第一个div元素会变红,这就是与first-child所区别的,只识别同类型的div元素*/
    E:last-of-type 选择父元素内具有指定类型的最后一个E元素,与E:nth-last-of-type(1)等同  
    <div class="parent">
    <div>第一个div元素</div>
    <div>第二个div元素</div>
      <p></p>
    </div>
    .parent div:nth-of-type(1){
    background-color: red;
    }
    /*此时第二个div元素会变红,这就是与last-child所区别的,只识别同类型的div元素*/
    E:only-child 选择父元素只包含一个子元素,且该子元素匹配E元素  
    <div class="parent">
    <div>第一个div元素</div>
    </div>
    <div class="parent">
    <div>第二个div元素</div>
    <div>第三个div元素</div>
    </div>
    .parent div:only-child{
    background-color: red;
    }
    /*第一个div元素会被匹配*/
    E:only-of-type 选择父元素只包含一个同类型子元素,且该子元素匹配E元素  
    <div class="parent">
    <div>第一个div元素</div>
    <p>第一个p元素</p>
    </div>
    <div class="parent">
    <div>第二个div元素</div>
    <div>第三个div元素</div>
    </div>
    <div class="parent">
    <div>第四个div元素</div>
    </div>
    /*第一和第四个div元素会被匹配*/
    E:empty 选择没有子元素的元素,而且该元素也不包含任何文本节点  
    <div class="parent">
    <div>第三个div元素</div>
    </div>
    <div class="parent">
    <div></div>
    </div>
    .parent div:empty{
    background-color: red;
    height: 10px;
    }
    /*最后一个空的div元素会被匹配*/

    7,否定伪类选择器

    选择器 功能描述
    E:not(F) 匹配所有除元素F外的E元素

    8,属性选择器语法

    选择器功能描述示例(以下值可以不用引号,class=child)
    [attribute] 用于选取带有指定属性的元素。
    <div class="parent">
    <div class="child">第一个div元素</div>
    <div>第二个div元素</div>
    </div>
    .parent div[class]{
    background-color: red;
    }
    /*第一个div元素会被变红,因为含有class属性*/

    [attribute=value] 用于选取带有指定属性和值的元素。  
    <div class="parent">
    <div class="child">第一个div元素</div>
    <div class="child child1">第二个div元素</div>
    </div>
    .parent div[class='child']{
    background-color: red;
    }
    /*第一个div元素会被变红*/
    [attribute~=value] 用于选取属性值中包含指定词汇的元素。  
    <div class="parent">
    <div class="child">第一个div元素</div>
    <div class="child child1">第二个div元素</div>
    <div class="child1">第三个div元素</div>
    </div>
    .parent div[class='child']{
    background-color: red;
    }
    /*第一和第二个div元素都会变红,第三个不会*/
    [attribute|=value] 用于选取带有以指定值开头的属性值的元素,该值必须是整个单词。  
    <div class="parent">
    <div class="child">第一个div元素</div>
    <div class="child child1">第二个div元素</div>
    <div class="child1">第三个div元素</div>
    </div>
    .parent div[class|='child']{
    background-color: red;
    }
    /*只有第一个div元素会变红*/
    [attribute^=value] 匹配属性值以指定值开头的每个元素。  
    <div class="parent">
    <div class="child">第一个div元素</div>
    <div class="child child1">第二个div元素</div>
    <div class="child1">第三个div元素</div>
    </div>
    .parent div[class^='child']{
    background-color: red;
    }
    /*三个div元素都会变红*/
    [attribute$=value] 匹配属性值以指定值结尾的每个元素。  
    <div class="parent">
    <div class="child">第一个div元素</div>
    <div class="child child1">第二个div元素</div>
    <div class="child1">第三个div元素</div>
    </div>
    .parent div[class^='child']{
    background-color: red;
    }
    /*只有第一个div元素会变红*/
    [attribute*=value] 匹配属性值中包含指定值的每个元素。  
    <div class="parent">
    <div class="child">第一个div元素</div>
    <div class="test child1">第二个div元素</div>
    <div class="child1">第三个div元素</div>
    </div>
    .parent div[class^='child']{
    background-color: red;
    }
    /*三个div元素都会变红*/
  • 相关阅读:
    String和enum的互相转换
    LeetCode: Sort Colors
    LeetCode: Subsets II
    LeetCode: Spiral Matrix II
    LeetCode: Subsets
    LeetCode: Sum Root to Leaf Numbers
    LeetCode: Sqrt(x)
    LeetCode: Sudoku Solver
    LeetCode: Spiral Matrix
    LeetCode: Substring with Concatenation of All Words
  • 原文地址:https://www.cnblogs.com/alex-xxc/p/14645081.html
Copyright © 2011-2022 走看看