zoukankan      html  css  js  c++  java
  • Css 后代选择器与子代选择器的区别

    后代选择器用空格,比如A B{border:1px solid red;}

     

    子代选择器用>, 比如A>B{border:1px solid red;}

    但是,如果你仔细想想,这俩个概念是不是有重复的地方,

    后代是不是也是子代?

    子代不也是后代吗?

    具体两者的关系不作讨论,我们来看看在css中具体有什么不同?

    先上代码:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>后代与子代选择器的区别</title>
        <!--<link rel="stylesheet" type="text/css" href="*.css"/>-->
        <script language="javascript" type="text/javascript"></script>
        <style>
            .zero>li
            {
                border:1px solid red;
            }
        </style>
    </head>
    <body>
        <ul class="zero" >
            <li>我是祖先</li>
           <ul>zero
               <li>我是第二代</li>
                    <ul>
                        <li>
                        我是第三代
                        </li>
                    </ul>
          </ul>
        </ul>
    </body>
    </html>
    

     子代选择器时效果图:

    后代选择器时效果图:

    可以说是区别相当的大了,从效果可以看出:

    后代指所有后代,而子代单指第一代

    果真如此吗?

    我们看看另一个例子:

    我们将css代码进行修改,而html代码不变:

    <style>
            .zero ul
            {
                color:red;
            }
        </style>
    

    使用 后代选择器运行效果图:

    使用子代选择器运行效果图:

     

    什么鬼,怎么完全一样?

    请注意这里的修改选项,我并不是直接用li标签,

    另外我修改的是颜色属性。

    事实上,上面的结论仍然是正确的

    之所以出现上面的情况,我们需要考虑到继承

    要知道,color这样的属性是可以继承的,也就是说

    子代的字体没有默认颜色,所以它从父亲那里继承

    可以,如果是这样的话,那为什么开始时没有继承呢?

    答案是:border属性无法继承,像border一样无法继承

    的属性还有:

    display、margin、border、padding、

    background、height、min-height、max-height、

    width、min-width、max-width、overflow、position、

    left、right、top、bottom、z-index、float、clear、

    table-layout、vertical-align、page-break-after、

    page-bread-before和unicode-bidi。

    这其中前面4个是经过我实测的,剩下的是查的网络上

    的资料,准确性无法确定。

    说这些是想弄明白为什么出现了一会效果一样,

    一会又效果不样的情况。

  • 相关阅读:
    hdu4521(线段树+dp)
    【Leetcode】Container With Most Water
    【Leetcode】Trapping Rain Water
    【Leetcode】Valid Sudoku
    【Leetcode】Combinations
    【Leetcode】Permutations II
    【Leetcode】Permutations
    【Leetcode】Permutation Sequence
    【Leetcode】Next Permutation
    【Leetcode】Remove Element
  • 原文地址:https://www.cnblogs.com/Andy963/p/7594603.html
Copyright © 2011-2022 走看看