首页 >web前端 >前端问答 >哪些属于css3层次选择器

哪些属于css3层次选择器

青灯夜游
青灯夜游原创
2021-12-16 14:37:072628浏览

属于css3层次选择器的有:1、后代选择器“E F”,选择E元素的全部后代F元素;2、子元素选择器“E>F”,选择E元素下的全部子元素F;3、相邻兄弟元素选择器“E+F”,选择紧接在E元素后的元素F;4、兄弟选择器“E~F”。

哪些属于css3层次选择器

本教程操作环境:windows7系统、CSS3&&HTML5版、Dell G3电脑。

后代选择器(E F)

后代选择器也被称做包含选择器,所起做用就是能够选择某元素的后代元素,好比说:E F,前面E为祖先元素,F为后代元素,所表达的意思就是选择了E元素的全部后代F元素,请注意他们之间须要一个空格隔开。这里F无论是E元素的子元素或者是孙元素或者是更深层次的关系,都将被选中,换句话说,不论F在E中有多少层关系,都将被选中:浏览器

.demo li {color: blue;}

上面表示的是,选中div.demo中全部的li元素spa

1.jpg

全部浏览器都支的后代选择器。3d

子元素选择器(E>F)

子元素选择器只能选择某元素的子元素,其中E为父元素,而F为子元素,其中E>F所表示的是选择了E元素下的全部子元素F。这和后代选择器(E F)不同,在后代选择器中F是E的后代元素,而子元素选择器E > F,其中F仅仅是E的子元素而以。blog

ul > li {
background: green;
color: yellow;
}

上在代码表示选择ul下的全部子元素li。如:bfc

2.jpg

IE6不支持子元素选择器。im

相邻兄弟元素选择器(E + F)

相邻兄弟选择器能够选择紧接在另外一元素后的元素,并且他们具备一个相同的父元素,换句话说,EF两元素具备一个相同的父元素,并且F元素在E元素后面,并且相邻,这样咱们就可使用相邻兄弟元素选择器来选择F元素。demo

li + li {
background: green;
color: yellow; 
border: 1px solid #ccc;
}

上面代码表示选择li的相邻元素li,咱们这里一共有十个li,那么上面的代码选择了从第2个li到 10 个li,一共九个,请看效果:db

3.jpg

由于上面的li+li其中第二li是第一li的相邻元素,第三个又是第二个相邻元素,所以第三个也被选择,依此类推,因此后面九个li都被选中了,若是咱们换过一种方式来看,可能会更好的理解一点:img

.active + li {
background: green;
color: yellow; 
border: 1px solid #ccc;
}

按照前面所讲的知识,这句代码很明显选择了li.active后面相邻的li元素,注意了和li.active后面相邻的元素仅只有一个的。如图:di

4.jpg

IE6不支持这个选择器

通用兄弟选择器(E ~ F)

通用兄弟元素选择器是CSS3新增长一种选择器,这种选择器将选择某元素后面的全部兄弟元素,他们也和相邻兄弟元素相似,须要在同一个父元素之中,换句话说,E和F元素是属于同一父元素以内,而且F元素在E元素以后,那么E ~ F 选择器将选择中全部E元素后面的F元素。好比下面的代码:

.active ~ li {
background: green;
color: yellow; 
border: 1px solid #ccc;
}

上面的代码所表示的是,选择中了li.active 元素后面的全部兄弟元素li,如图所示:

5.jpg

通用兄弟选择器和相邻兄弟选择器极其类似,只不过,相邻兄弟选择器仅选择是元素的仅与其相邻的后面元素(选中的仅一个元素);而通用兄弟元素选择器,选中的是元素相邻的后面兄弟元素,这样提及来可能会有迷糊,你们能够仔细看看其相邻兄弟的效果图。

IE6不支持这种选择器的用法。

(学习视频分享:css视频教程

以上是哪些属于css3层次选择器的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn