【CSS选择符】后代选择符

作者: 德育处主任 | 来源:发表于2017-12-26 21:49 被阅读10次
    微信订阅号:rabbit_svip

    在学习后代选择符之前,首先要了解一下组成一个网页的HTML家谱,每个HTML标签标示其中一个家庭成员。网页中的第一个HTML标签(<html>标签),相当于所有其他标签的始祖。<head>和<body>标签在<html>标签里,所以<html>标签是二者的祖辈。

    先看看一段HTML代码:

    <html>
        <head>
            <title>Document</html>
        </head>
        <body>
            <h1>Header</h1>
            <p> A paragraph of <strong>important</strong>text.</p>
        </body>
    </html>
    

    以下是结构示意图


    image.png
    1. 祖辈:外层HTML标签是内层标签的祖辈。<body>标签是其内部所有标签(<h1>、<p>和<strong>标签)的祖辈。
    2. 后代:标签里的其他标签是后代。<body>标签是<html>标签的后代,<p>标签即使<body>标签的后代,也是<html>标签的后代。
    3. 父辈:父辈标签是另一个标签的直接祖辈。<html>标签是<head>和<body>的父辈,而不是其他标签的父辈;<p>标签是<strong>标签的父辈。
    4. 子代:直接被另一个标签保卫的标签是外层标签的子代。<h1>和<p>是标签是<body>标签的子代,而<strong>标签不是。<strong>标签直接包含在<p>标签里,所以是<p>标签的子代。
    5. 同辈:父辈相同的标签叫同辈标签,相当于兄弟姐妹。如<head>和<body>是同辈标签,<h1>和<p>也是同辈标签。

    在CSS中,后代选择器的写法是:
    祖辈 后代 { 样式 ; }

    首先,先找到祖辈,然后中间有一个空格,空格后面跟着后代。
    例如
    header h1 { color: red;}

    意思就是<header>标签里的所有<h1>标签,字体都改成红色。
    在<header>标签外的<h1>标签,不会受到上面那行代码的影响。

    后代选择符可以由2个以上元素组成,例如:

    • ul li a
    • body li a
    • html li a
    • html body ul li a

    以上四个选择符的作用相同,因此表明,无需指明目标标签的所有直系。
    一般来说,应该使用能达到目的的最简短的后代选择符。所有标签都在<html>和<body>标签里,因此没要在后代选择符中指定<html>和<body>。

    后代选择符里的选择符数量会影响冲突样式的处理方式,这种冲突处理机制成为特指度。会在后面的笔记中讲到。

    同样的,后代选择符也不局限于只能使用类型选择符。
    可以使用不同类型的选择符构建复杂的后代选择符。例如
    .intro a { color: yellow; }

    意思就是:如果某个标签的类为intro,就把上述样式应用到这个标签的所有链接后代(a)上。






    注意:

    p.intro和p .intro不一样。前者是没空格隔开的

    p.intro的意思是:类为intro的<p>标签。

    p .intro的意思是<p>标签里面的所有类为intro的标签。


    HTML与CSS 目录:HTML与CSS

    上一篇:【CSS选择符】群组选择符 和 通用选择符

    下一篇:【CSS选择符】伪类和伪元素

    相关文章

      网友评论

        本文标题:【CSS选择符】后代选择符

        本文链接:https://www.haomeiwen.com/subject/ydgegxtx.html