html5--6-9 CSS选择器6--伪类选择器

html5--6-9 CSS选择器6--伪类选择器

实例

1 @charset="UTF-8";
2 /*:root{background: green}*/
3 /*li:first-child{color: red}*/
4 /*选择ul的元素里面是第一个子元素的*/
5 /*ul>li:first-child{color: red}*/
6 /*li:last-child{color: red}*/
7 /*li:only-child{color: green}*/
8 p:only-of-type{color: red}
View Code
 1 <!DOCTYPE html>
 2 <html lang="zh-cn">
 3 <head>
 4     <meta charset="utf-8">
 5     <title>6-9课堂演示</title>
 6     <link rel="stylesheet" type="text/css" href="style.css">
 7     <style type="text/css">
 8 
 9     </style>
10 </head>
11 <body>
12     <ul>
13         <li>我是ul的子元素1</li>
14         <li>我是ul的子元素2
15             <ol>
16                 <li>我是ul的孙元素1</li>
17                 <li>我是ul的孙元素2</li>
18                 <li>我是ul的孙元素3</li>
19                 <li>我是ul的孙元素4</li>
20                 <li>我是ul的孙元素5</li>
21             </ol>
22         </li>
23         <li>我是ul的子元素3,
24             <ul>我只有一个子元素
25                 <li>我也li元素的内容</li>
26             </ul>
27         </li>
28         <li>我是ul的子元素4</li>
29         <li>我是ul的子元素5</li>
30     </ul><hr>
31     <div>
32         <h3>我是标题</h3>
33         <p>我是段落p1</p>
34     </div>
35     <hr>
36     <div>
37         <p>我是段落p1</p>
38         <p>我是段落p1</p>
39     </div><hr>
40     <div>
41         <p>我是段落p1</p>
42         <p>我是段落p2</p>
43         <p>我是段落p3</p>
44     </div><hr>
45     <div>
46         <p>
47         锦瑟 ---李商隐<br><br>
48         </p>
49         <p>
50         锦瑟无端五十弦,一弦一柱思华年。<br><br>
51         庄生晓梦迷蝴蝶,望帝春心托杜鹃。<br><br>
52         沧海月明珠有泪,蓝田日暖玉生烟。<br><br>
53         此情可待成追忆?只是当时已惘然。<br><br>
54         </p>
55     </div>
56     <table style=" 400px;height: 80px;padding: 15px">
57         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
58         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
59         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
60         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
61         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
62         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
63         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
64         <tr><td>单元格</td><td>单元格</td>单元格<td>单元格</td></tr>
65     </table>
66 
67   <a href="#">搜索</a><br>
68   <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br> <br>
69 </body>
70 </html>
View Code

学习要点

  • 掌握常用的CSS选择器
  • 了解不太常用的CSS选择器

什么是选择器

当我们定义一条样式时候,这条样式会作用于网页当中的某些元素,所谓选择器就是样式作用的对象.

插入样式的三种方法

    1. 内联样式表(行内)
    2. 内部样式表(style中)
    3. 外部样式表
      • 创建一个外部样式表
      • 在head中使用link元素插入样式表


CSS语法

  • 单一元素的多个属性之间用分号隔开;若只有一个可以省略
  • 多个元素之间用逗号隔开
  • 如果值为若干单词,则要给值加引号;除了这种情况外其他时候不可以加引号
  • css代码的注释
  • 样式的优先顺序:
    • 设计者设计的样式>浏览器用户自定义的样式>浏览器自设的样式
    • 强制优先级:!important
    1. 行内(内联)样式
    2. 内部样式:style中的样式
    3. 外部样式
  • 层叠、继承、冲突
    • 外观样式--比如字体、颜色可以继承;而布局有关的样式不可以继承,比如边框等
  • 可以在同一个 HTML 文档内部引用多个外部样式表。


CSS选择器

    • 常用选择器
      1. 通用选择器:“*”
      2. 元素选择器
      3. id选择器:前面有一个 # 号
      4. 类选择器:前面加符号 .
        • 给一个元素加上多个类名
        • 指定某一特定的类
  • 属性选择器
      • E[att] :选择具有att属性的E元素。需要选择有某个属性的元素,而不论属性值是什么,可以使用简单属性选择器。

    可以根据多个属性进行选择,只需将属性选择器链接在一起即可。

    • E[att="val"]:选择具有att属性且属性值等于val的E元素。进一步缩小选择范围,(只选择有特定属性值的元素。)
    • E[att~="val"]:选择具有att属性且属性值有多个,其中一个的值等于val的E元素。
    • E[att|="val"]:选择具有att属性且属性值为以val开头并用连接符"-"分隔的字符串的E元素。
    • E[att^="val"]:选择具有att属性且属性值为以val开头的字符串的E元素。
    • E[att$="val"]:选择具有att属性且属性值为以val结尾的字符串的E元素。
    • E[att*="val"]:选择具有att属性且属性值为包含val的字符串的E元素。

  • 关系选择器
    • 后代选择器(包含选择器)ul li{}:后代选择器又称为包含选择器。后代选择器可以选择作为某元素后代的元素。
    • 子元素选择器ul>li:与后代选择器相比,子元素选择器只能选择作为某元素子元素的元素,缩小了选择范围
    • 相邻选择符:E+F:选择紧贴在E元素之后F元素。
    • 兄弟选择器E~F:选择E元素所有兄弟元素F。(只可以选择到之后的元素)

  • 伪元素选择器
    • E:first-letter/E::first-letter 设置元素内的第一个字符的样式。
    • E:first-line/E::first-line设置元素内的第一行的样式。
    • E:before/E::before在每个 E元素的内容之前插入内容。用来和content属性一起使用
    • E:after/E::after在每个E元素的内容之后插入内容。用来和content属性一起使用
    • E::selection设置对象被选择时的颜色。

  • 伪类选择器结构伪类选择器
    • E:first-child 父元素的第一个子元素E。
    • :root:选择文档的根元素。
    • E:last-child:最后一个子元素E。
    • E:only-child:仅有的一个子元素E。
    • E:only-of-type:只有一种类型的子元素。
    • E:nth-child(n):匹配父元素的第n个子元素E。
    • E:nth-last-child(n):匹配父元素的倒数第n个子元素E。
    • E:first-of-type :匹配同类型中的第一个同级元素E。
    • E:last-of-type:匹配同类型中的最后一个同级元素E。
    • E:nth-of-type(n):匹配同类型中的第n个同级兄弟元素E。
    • E:nth-last-of-type(n):匹配同类型中的倒数第n个同级兄弟元素E。
    • E:empty :匹配没有任何子元素(包括text节点)的元素E。
    UI伪类选择器
    • E:first-child 父元素的第一个子元素E。

原文地址:https://www.cnblogs.com/Renyi-Fan/p/7993258.html