• CSS3 结构性伪类选择器(1)


    1.CSS3 结构性伪类选择器—root

    :root选择器就是匹配元素E所在文档的根元素。在HTML文档中,根元素始终是<html>。

    “:root”选择器等同于<html>元素,简单点说:

    :root{background:orange}

    html {background:orange;}

    示例演示:

    通过“:root”选择器设置背景颜色

    HTML代码:

    <div>:root选择器的演示</div>

    CSS代码:

    :root {
      background:orange;
    }

    演示结果:

    “:root”选择器等同于<html>元素,简单点说:

    :root{background:orange}

    html {background:orange;}

    得到的效果等同。

    建议使用:root方法。

    :root 代码示例:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>结构性伪类选择器—root</title>
    
        <style type="text/css">
            :root{
                background: skyblue;
               color: blue;
            }
    
        </style>
    </head>
    <body>
    <div>Root选择器修改HTML元素的背景颜色</div>
    </body>
    </html>

    效果:

    html 代码示例:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>结构性伪类选择器—root</title>
    
        <style type="text/css">
            html{
                background: rebeccapurple;
               color: blue;
            }
    
        </style>
    </head>
    <body>
    <div>Root选择器修改HTML元素的背景颜色</div>
    </body>
    </html>

    效果:

    2.:not选择器称为否定选择器

    :not选择器称为否定选择器,和jQuery中的:not选择器一模一样,可以选择除某个元素之外的所有元素。就拿form元素来说,比如说你想给表单中除submit按钮之外的input元素添加红色边框,CSS代码可以写成:

    form {
       200px;
      margin: 20px auto;
    }
    div {
      margin-bottom: 20px;
    }
    input:not([type="submit"]){
      border:1px solid red;
    }

    相关HTML代码:

    <form action="#">
      <div>
        <label for="name">Text Input:</label>
        <input type="text" name="name" id="name" placeholder="John Smith" />
      </div>
      <div>
        <label for="name">Password Input:</label>
        <input type="text" name="name" id="name" placeholder="John Smith" />
      </div>
      <div>
        <input type="submit" value="Submit" />
      </div>
    </form>  ​

    演示结果:

     代码示例:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>结构性伪类选择器—not</title>
    
        <style type="text/css">
            div{
                padding: 10px ;
                200px;
    
            }
            div:not([id="footer"]){
                background: orange;
            }
            li{
                background: skyblue;
                250px;
            }
            li:not([id="class2"] ){
                background: slateblue;
            }
        </style>
    
    </head>

    演示结果:

    3.CSS3 结构性伪类选择器—empty

    :empty选择器表示的就是空。用来选择没有任何内容的元素,这里没有内容指的是一点内容都没有,哪怕是一个空格。

    示例显示:

    比如说,你的文档中有三个段落p元素,你想把没有任何内容的P元素隐藏起来。我们就可以使用“:empty”选择器来控制。

    HTML代码:

    <p>我是一个段落</p>
    <p> </p>
    <p></p>​

    CSS代码:

    p{
     background: orange;
     min-height: 30px;
    }
    p:empty {
      display: none;
    }​

    演示结果:

     代码示例:

     <!DOCTYPE html>
    <html>
    <head>
        <meta charset="utf-8">
        <title>结构性伪类选择器—empty</title>
       <style type="text/css">
           div {
               background: blueviolet;
               min-height: 30px;
                200px;
           }
           div:empty {
               border: 1px dashed red;
               background: skyblue;
           }
       </style>
    </head>
    <body>
    <div>我这里有内容</div>
    <div> <!-- 我这里有一个空格 --></div>
    <div></div><!-- 我这里任何内容都没有 -->
    </body>
    </html>

    演示结果:

    4.CSS3 结构性伪类选择器—target

    :target选择器称为目标选择器,用来匹配文档(页面)的url的某个标志符的目标元素。我们先来上个例子,然后再做分析。

    示例展示

    点击链接显示隐藏的段落。

    HTML代码:

    <h2><a href="#brand">Brand</a></h2>
    <div class="menuSection" id="brand">
        content for Brand
    </div>

    CSS代码:

    .menuSection{
      display: none;
    }
    :target{/*这里的:target就是指id="brand"的div对象*/
      display:block;
    }

    演示结果:

    分析:

    1、具体来说,触发元素的URL中的标志符通常会包含一个#号,后面带有一个标志符名称,上面代码中是:#brand

    2、:target就是用来匹配id为“brand”的元素(id="brand"的元素),上面代码中是那个div元素。

    多个url(多个target)处理:

    就像上面的例子,#brand与后面的id="brand"是对应的,当同一个页面上有很多的url的时候你可以取不同的名字,只要#号后对的名称与id=""中的名称对应就可以了。
    如下面例子:
    html代码:  

    <h2><a href="#brand">Brand</a></h2>
    <div class="menuSection" id="brand">
      content for Brand
    </div>
    <h2><a href="#jake">Brand</a></h2>
    <div class="menuSection" id="jake">
     content for jake
    </div>
    <h2><a href="#aron">Brand</a></h2>
    <div class="menuSection" id="aron">
        content for aron
    </div>
    

    css代码:

    #brand:target {
      background: orange;
      color: #fff;
    }
    #jake:target {
      background: blue;
      color: #fff;
    }
    #aron:target {
      background: red;
      color: #fff;
    }
    

    上面的代码可以对不同的target对象分别设置不的样式。

     代码示例:

    <!DOCTYPE html>
    <html>
    <head>
        <meta charset="UTF-8">
        <title>target demo</title>
        <style type="text/css">
                          div:target{
                              background: purple;border: 1px solid black;
                          }
        </style>
    </head>
    <body>
        <ul>
            <li><a href="#tab1">tab1</a></li>
            <li><a href="#tab2">tab2</a></li>
            <li><a href="#tab3">tab3</a></li>
            <li><a href="#tab4">tab4</a></li>
        </ul>
                 <div id="tab1">this is tab1</div>
                 <div id="tab2">this is tab2</div>
                 <div id="tab3">this is tab3</div>
                 <div id="tab4">this is tab4</div>
    </body>
    </html>

    演示结果:

    转载:http://www.imooc.com/code/736

  • 相关阅读:
    C# 學習使用StatusStrip
    初學C#打印
    C# 學習使用ErrorProvider
    C# 字符串中增、刪、替換字符學習
    mos开发系列教程八:页面代码研究地图控件页面结构
    MapGuide open source开发系列教程五: 屏幕坐标与地图坐标(问题)已修改
    ajax学习笔记一:动态更改div位置
    mos开发系列教七:框架分析
    mos开发系列教程十:说明
    MapGuide open source开发系列教程六: 地图状态与事件(含问题)
  • 原文地址:https://www.cnblogs.com/guangzhou11/p/7347054.html
Copyright © 2020-2023  润新知