CSS3 新增选择器

属性选择器

根据元素特定属性的来选择元素,而不需动用类或id选择器

  • 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元素
input[type="text"] {
  color: pink;
}

注意:类选择器,属性选择器,伪类选择器这些权重为10

结构伪类选择器

主要根据文档结构来选择元素,常用于根据父级选择里面的子元素

  • E:first-child 匹配元素中的第一个元素E
  • E:last-child 匹配父元素中的最后一个E元素
  • E:nth-child(n) 匹配父元素中的第n各子元素E
  • E:first-of-type 指定类型E的第一个
  • E:last-of-type 指定类型E的最后一个
  • E:nth-of-type(n) 指定类型E的第n个
th-child(n):
  • n可以是数字,关键字或公式
  • n如果是数字,就是选择第n个子元素,里面数字从1开始
  • n可以是关键字,even偶数,odd奇数
  • n可以是公式:常见的公式如下(如果n施工时,则从0开始计算,但是第0各元素或者超出了元素的个数会被忽略)
  • 所有孩子排序,之后看前面的选择器

数字

/* 选择ul里面的第三个li */
ul li:nth-child(3) {
  color: red;
}

关键字

/* 隔行换色 */
ul li:nth-child(even) {
  background-color: #ccc;
}
ul li:nth-child(odd) {
  background-color: gray;
}

公式

/* 选择全部 */
ul li:nth-child(n) {
  background-color: gray;
}

其中,公式可以为:

  • n 全部
  • 2n 偶数
  • 2n+1 奇数
  • n+2 从第五个(包括第五个)倒最后
  • -n+5 前5个(包括第五个)
nth-of-type(n)
  • 将指定的孩子排列序号
  • 先看选择器,然后看第几个孩子
  • 写法和nth-child类似
nth-child与nth-of-type区别

1.nth-child对父元素里面所有的孩子排序选择(序号是固定的),先找到第n个孩子,然后看看是否和E匹配
2.nth-of-type对父元素里面指定元素进行排序选择,先去匹配E,然后找第几个孩子

伪元素选择器(重点)

伪元素选择器可以帮助我们利用CSS创建新标签元素,而不需要HTML标签,从而简化HTML结构

  • ::before 在元素内部的前面插入内容
  • ::after 在元素内部的后面插入内容
    注意:
    1.被before和after常见一个元素,单时属于行内元素
    2.新创建的这个元素在文档中是找不到的,所以我们称之为为元素
    3.语法: element::before {}
    4.before和after必须有 content属性
    5.before在父元素内容的前面创建元素,after则在后面
    6.为元素选择器和标签选择器一样,权重为1
p::before {
  position: absolute;
  right: 20px;
  top: 10px;
  content: '\e91e';
  fonst-size: 20px;
}

你可能感兴趣的:(CSS3 新增选择器)