CSS3新增了哪些选择器?(属性、结构伪类、伪元素选择器)

在css3提供的新选择器之前,选择一个元素需要借助id或者class,css3新增的选择器可以更灵活的去选择需要的元素,那css3提供了哪些好用的选择器呢?

首先就是属性选择器,我们可以通过属性选择器在同样的标签/类中选择出具有相同属性的元素,不用额外再添加class或者id。

比如需要选择出input标签中具有value属性的内容,就可以按以下方式

// css
input[value]{
   color: #333;
}

// html
<input type="text" value="请输入用户名">
<input type="text">

属性选择器还有以下匹配规则(E表示选择器,att表示属性值,val表示匹配的内容)

选择符 简介
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为password的元素

// css
input[type=password]{
   color: #000
}
// html
<input type="text">
<input type="password">

选择出div标签中class以movie开头的元素

// css
div[class^=movie]{
    color: brown
}

// html
<div class="movie-sky">天空之城</div>
<div class="movie-cat">龙猫</div>
<div class="movie-windy">起风了</div>
<div class="tv">武林外传</div>
属性选择器.png

按照以上五种属性选择规则,可以自由的选择具有某些特征的元素,那么如果此时我需要选择的元素没有单独的属性呢。
比如我想要在一串列表中选择出奇数项和偶数项元素,分别设置不同的背景颜色,此时就需要结构伪类选择器登场了。
结构伪类选择器可以按下标选出指定项,比如第一项 :first-child,最后一项 :last-child,奇数项 :nth-child(even),偶数项 :nth-child(odd),第任何一项 :nth-child(n)

拿上述选择器做一个演示

// html
<ul>
  <li>千与千寻的神隐</li>
  <li>起风了</li>
  <li>龙猫</li>
  <li>天空之城</li>
  <li>魔女宅急便</li>
</ul>

// css
ul :first-child {
  color: brown // 选择ul的第一个子元素设置字体颜色为棕色
}

ul :last-child {
   text-decoration: underline; // 选择ul的最后一个子元素设置下划线
}

ul :nth-child(even){
   font-weight: bold;         // 选择ul的偶数子元素 设置字体加粗(下标从1开始)
}
结构伪类选择器合并使用.png

可以看到,以上每一个伪类选择器与前一个选择器并没有直接连在一起,都有一个空格,那连在一起表示什么意思呢?拿 :first-child来举例,:last-child和 :nth-child都是类似的原理

ul :first-child  表示选择ul里的第一个子元素 
ul:first-child   表示选择第一个ul元素

以下为 ul:first-child


first-child.png

如果我们需要对子元素的选择器属性进行校验,希望选择ul里的第一个子元素,并且是li,那么就可以这样定义

ul li:first-child
first-child.png

但是如果第一个元素与选定的元素不匹配,那么设置的样式就不会生效

// css
div p:first-child {
   color: brown  // 先找到div的第一个子元素,发现它并不是p元素,所以样式不生效
}

// html
<div>
   <div>div----千与千寻的神隐</div>
    <p>p----起风了</p>
    <p>p----龙猫</span>
    <h6>h6----天空之城</h6>
    <div>div----魔女宅急便</div>
</div>
first-child.png

那如果,我们想要选择div下面的第一个p元素呢?此时就可以使用 :first-of-type

// 表示选择div下p元素的第一个子元素
div p:first-of-type {
   color: brown
}
first-of-type.png

那如果没有限定指定的子元素类型,所有的不同类型的子元素都会被设置样式

// css
div :first-of-type {
   color: brown
}
first-of-type-2.png

与 :first-of-type 类似的还有以下两种选择器,分别是 :last-of-type(选择某种类型的最后一个子元素),:nth-of-type(按指定规则选择元素)

// css
div :first-of-type {
   color: brown
}

div :last-of-type {
   text-indent: 10px;
}

div :nth-of-type(2n+1) {
   text-decoration: underline;
}
结构伪类选择器合并使用.png

来一个表格总结以下以上六种结构伪类选择器

选择符 简介 备注
E :first-child 选择E元素的第一个子元素 E A:first-child(选择E元素的第一个子元素,且该子元素是A类型元素)
E :last-child 选择E元素的最后第一个子元素 E A:last-child(选择E元素的最后第一个子元素,且该子元素是A类型元素)
E :nth-child(n) 选择E元素的指定规则元素,比如 1、2、3这样的数字,even(偶数)、odd(基数)这样的关键字,n或者2n+1这样的表达式 E A:nth-child(n)(选择E元素中符合指定规则的子元素,且该子元素是A类型的元素)
E :first-of-type 选择E元素中不同类型的子元素中的第一个 E A:first-of-type(选择E元素中子元素为A,A元素中的第一个)
E :last-of-type 选择E元素中不同类型的子元素中的最后一个 E A:last-of-type(选择E元素中子元素为A,A元素中的最后一个)
E :nth-of-type(n) 选择E元素的不同类型的指定规则 E A:nth-of-type(选择E元素中子元素为A,A元素的指定规则)

以上的属性选择器和结构伪类选择器都是操作元素本身,那接下来这个选择器就很神奇,它会添加一个新的不存在的元素,并操作,一起来看看伪元素选择器。

伪元素选择器有两个,::before,在元素的前面添加一个行内元素,::after,在元素的后面添加一个行内元素,需要添加两个冒号,为了兼容,也可以只写成一个冒号


伪元素图示.png

设置伪元素,必须的属性是 content,其它的属性可以根据自己的需要设置,它常见的有以下几种用途,添加一个小图标,比如圆点,箭头


伪元素选择器.png

实现代码如下

// css
div {
   position: relative;
}

div::after {
   position: absolute;
   top: 7px;
   left: 70px;
   content: '';
   display: block;
   width: 7px;
   height: 7px;
   border-right: 1px solid #333;
   border-top: 1px solid #333;
   transform: rotate(45deg)
}

// html
<div>查看更多</div>

或者设置鼠标滑动后添加一个遮罩层,效果显示如下


伪类选择器实现遮罩层.gif
实现代码如下
// css
div{
   position: relative;
   width: 200px;
   height: 200px;
   margin-right: 60px;
}

img {
   width: 100%;
   height: 100%;
}

div::after {
   display: none;
   position: absolute;
   top: 0;
   left: 0;
   content: '';
   width: 100%;
   height: 100%;
   background: url(./src/broadcast.png) rgba(0,0,0,.5) center center no-repeat
}

div:hover::after{
   display: block;
}

// html
<div>
   <img src="./src/pig.jpg">
</div>

css3增加的以上选择器可以减少html的结构,更加灵活的获取需要的元素

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,271评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,275评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,151评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,550评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,553评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,559评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,924评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,580评论 0 257
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,826评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,578评论 2 320
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,661评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,363评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,940评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,926评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,156评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,872评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,391评论 2 342

推荐阅读更多精彩内容