css之选择器篇
css能够获取到HTML结构上的元素,这个是怎么实现的了?
在我们看来这是个很神奇的事情,css可以写在页面之外,也可以写在页面内,而都不会影响到它去
获取这个元素,还有无论这个HTML结构多么复杂,这个css也能准确获取你所要的HTML元素,既然
那么强大,那么是不是实现过程也是很困难呢?
只能绝对说这个很很很很简单的。
这只要记住以下的选择符即可,噢,还有上一篇还介绍了些选择符。
子选择符
选择所有作为E元素的子元素F。 E>F
例子:
<style>
p>a{
color: black;
}
</style> <p>火狐是个<a href="#">浏览器</a></p>
相邻选择符
选择紧贴在E元素之后F元素。E+F
<style>
p+p{
font-weight: bold;
}
</style> <p>火狐是个<a href="#">浏览器</a></p>
<p>IE是个坑爹的浏览器</p>
兄弟选择符
选择E元素所有兄弟元素F。E~F
<style>
li~li{
color: red;
}
</style> <ul>
<li>大明的子女1</li>
<li>大明的子女2</li>
<li>大明的子女3</li>
<li>大明的子女4</li>
<li>大明的子女5</li>
<li>大明的子女6</li>
<li>大明的子女7</li>
<li>大明的子女8</li>
<li>大明的子女9</li>
<li>大明的子女10</li>
</ul>
这个选择符选择不包括自己之外所有F选择符。
id 及 class 选择符
<p id="p1"> 这是一个段落 </p>
#p1 {
font-size:12px;
font-weight:bold;
}
<p class="p1"> 这是一个段落 </p>
.p1 {
font-size:12px;
font-weight:bold;
}
id 选择器可以为标有特定 id 的 HTML 元素指定特定的样式。
在网页中,每个id名称中只能使用一次,不得重复。
与id 不同,class 允许重复使用。比如页面中的多个元素,都可以使用同一个样式定义。
伪类选择符
E:link 设置超链接a在未被访问前的样式。
E:visited 设置超链接a在其链接地址已被访问过时的样式。
E:hover 设置元素在其鼠标悬停时的样式。
E:active 设置元素在被用户激活(在鼠标点击与释放之间发生的事件)时的样式。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>伪类</title>
<style>
a:link{
color: #00ffff;
}
a:visited{
color: #000;
}
a:hover{
color: #ff7600;
}
a:active{
color: #eee;
}
</style>
</head>
<body>
<a href="#">click into</a>
</body>
</html>
注意:这个4个伪类选择符的顺序按照 link-visited-hover-active
顺序乱来会出现问题,这个问题请移步到上篇扩展内容
E:focus 设置元素在成为输入焦点(该元素的onfocus事件发生)时的样式。
使用在表单中或能获取光标的元素上。
input:focus{
outline: 2px solid #ff7600;
}
<input type="text">
E:lang(fr) 匹配使用特殊语言的E元素。很少用
匹配中英双版,可能要使用到。
p:lang(en){
font-size: 14px;
}
<p>IE是个坑爹的浏览器</p>
E:not(s) 匹配不含有s选择符的元素E。
ul li:not(.li3){
color: #fff;
}
<ul>
<li>大明的子女1</li>
<li>大明的子女2</li>
<li class="li3">大明的子女3</li>
<li>大明的子女4</li>
<li>大明的子女5</li>
<li>大明的子女6</li>
<li>大明的子女7</li>
<li>大明的子女8</li>
<li>大明的子女9</li>
<li>大明的子女10</li>
</ul>
E:root 匹配E元素在文档的根元素。常指html元素
p:root{
background: blue;
}
E:first-child 匹配父元素的第一个子元素E。
ul:first-child{
font-size: 15px;
}
<ul>
<li>大明的子女1</li>
<li>大明的子女2</li>
<li>大明的子女3</li>
<li>大明的子女4</li>
<li>大明的子女5</li>
<li>大明的子女6</li>
<li>大明的子女7</li>
<li>大明的子女8</li>
<li>大明的子女9</li>
<li>大明的子女10</li>
</ul>
第一个li被匹配;
E:last-child 匹配父元素的最后一个子元素E。
ul:last-child{
color: blue;
}
最后一个li被匹配;
E:only-child
body:only-child{
color: blue;
}
<p>火狐是个<a href="#">浏览器</a></p>
<p>IE是个坑爹的浏览器</p>
<input type="text">
input被匹配;
E:nth-child(n) 匹配父元素的第n个子元素E。
ul:nth-child(1){
color: blue;
}
ul下的第一个li被匹配;
E:nth-last-child(n) 匹配父元素的倒数第n个子元素E。
ul:nth-last-child(1){
color: blue;
}
ul的子元素li的倒数第一个被匹配到。
E:first-of-type 匹配同类型中的第一个同级兄弟元素E。
li:first-of-type{
font-weight: bold;
}
同类型li的第一个被选中;
E:last-of-type 匹配同类型中的最后一个同级兄弟元素E。
li:last-of-type{
border: 1px solid #ddd;
}
同类型li的最后一个被选中;
E:only-of-type 匹配同类型中的唯一的一个同级兄弟元素E。
li:only-of-type{
font-weight: bold;
}
E:nth-of-type(n) 匹配同类型中的第n个同级兄弟元素E。
li:nth-of-type(3){
font-weight: bold;
}
第三li被匹配;
E:nth-last-of-type(n) 匹配同类型中的倒数第n个同级兄弟元素E。
li:nth-last-of-type(3){
background: green;
}
倒数第三个被匹配;
E:empty 匹配没有任何子元素(包括text节点)的元素E。
E:checked 匹配用户界面上处于选中状态的元素E。 (用于input type为radio与checkbox时)
input:checked{
width: 100px;
}
<input type="checkbox" name="name" id="1">
<input type="checkbox" name="name" id="2">
<input type="checkbox" name="name" id="3">
<input type="checkbox" name="name" id="4">
E:enabled 匹配用户界面上处于可用状态的元素E。
E:disabled 匹配用户界面上处于禁用状态的元素E。
E:target 匹配相关URL指向的E元素。
ul li a:target{
color: red;
}
<ul>
<li><a href="#nav1" id="nav1">导航一</a></li>
<li><a href="#nav2" id="nav2">导航二</a></li>
<li><a href="#nav3" id="nav3">导航三</a></li>
</ul>
这个一定要设置路径URL,不是不行。只能使用与锚点,就是本页跳转。
不过可以使用来代表激活状态,以前是需要js实现的。
ok~
扩展小知识:
接上一篇又补充一些,让我们对css的理解更加深刻。
层叠样式表
层叠是什么意思?为什么这个词如此重要,以至于要出现在它的名称里。
层叠可以简单地理解为冲突的解决方案。
优先级规则可以表述为
行内样式>ID样式>类别样式>标记样式
在复杂的页面中,某一个元素有可能会从很多地方获取样式,例如一个网站的某一级标题整体设置为使用绿色,而对某个特殊栏目
需要使用蓝色,这样在栏目中就需要覆盖通用的样式设置。在很简单的页面中,这样的特殊需求实现起来不会很难,但是如果网站
的结构很复杂,就完全有可能代码变得非常混乱,可能出现无法找到某个元素的样式来自于哪条规则的情况。因此,必须要充分理
解css中“层叠”的原理。
计算冲突样式的优先级是一个比较复杂的过程,并不仅仅是上面这个简单的优先级规则可以完全描述的。但是使用者可以把把握 一个大的
原则,就是“越特殊的样式,优先级越高”行内样式对指定的一个元素产生影响,非常特殊,ID是针对某个元素的,因此它一定比应用于多个
元素的类别样式特殊。特殊性越高的元素,优先级越高。
css之选择器篇的更多相关文章
- css中选择器的使用
css是英文Cascading Style Sheets的缩写.它是一种用来表现HTML(标准通用标记语言的一个应用)或XML(标准通用标记语言的一个子集)等文件样式的计算机语言.我们再将html比喻 ...
- CSS类选择器和ID选择器
CSS类选择器和ID选择器皆允许以一种独立于文档元素的方式来指定样式,同时二者皆区分大小写. 区别如下: 第一:在同一个页面内,不允许有相同名字的id对象出现,但是允许相同名字的class 第二:当页 ...
- 2天驾驭DIV+CSS (技巧篇)(转)
这是去年看到的一片文章,感觉在我的学习中,有不少的影响.于是把它分享给想很快了解css的兄弟们.本文是技巧篇. 基础篇[知识一] “DIV+CSS” 的叫法是不准确的[知识二] “DIV+CSS” ...
- 2天驾驭DIV+CSS (实战篇)(转)
这是去年看到的一片文章,感觉在我的学习中,有不少的影响.于是把它分享给想很快了解css的兄弟们.本文是实战篇. 基础篇[知识一] “DIV+CSS” 的叫法是不准确的[知识二] “DIV+CSS” ...
- 2天驾驭DIV+CSS (基础篇)(转)
这是去年看到的一片文章,感觉在我的学习中,有不少的影响.于是把它分享给想很快了解css的兄弟们. 基础篇[知识一] “DIV+CSS” 的叫法是不准确的[知识二] “DIV+CSS” 将你引入两大误区 ...
- 小tip: CSS后代选择器可能的错误认识——张鑫旭
一.关于类选择器的一个问题 假设有下面一个面试题,CSS代码如下: .red { color: red; } .green { color: green; } HTML如下: <div clas ...
- CSS 从入门到放弃系列:CSS的选择器和优先级
CSS的选择器和优先级 CSS的N种选择器 !important 其实这个玩意不算什么选择器,放在这只是为了突出这个选择器优先级或者说权重的从高到低而已.. 内联方式(行间样式) <div st ...
- CSS系列(7)CSS类选择器Class详解
这一篇文章,以笔记形式写. 1, CSS 类选择器详解 http://www.w3school.com.cn/css/css_selector_class.asp 知识点: (1) 使用类选择 ...
- CSS 属性选择器的深入挖掘
CSS 属性选择器,可以通过已经存在的属性名或属性值匹配元素. 属性选择器是在 CSS2 中引入的并且在 CSS3 中得到了很好拓展.本文将会比较全面的介绍属性选择器,尽可能的去挖掘这个选择器在不同场 ...
随机推荐
- java核心知识点学习----多线程并发之线程同步
1.什么是线程同步? 多线程编程是很有趣的事情,它很容易出现"错误情况",这种情况不是由编码造成的,它是由系统的线程调度造成的,当使用多个线程来访问同一个数据时,很容易出现&quo ...
- Hex编码字节
1.将字节数组转换为字符串 /** * 将字节数组转换为字符串 * 一个字节会形成两个字符,最终长度是原始数据的2倍 * @param data * @return */ public static ...
- 存在网路的情况下重命名SDE中数据图层错误(The orphan junction feature class cannot be renamed)
运行环境为ArcGIS9.3,VS2008. 问题描述:数据通过SDE存储在Oracle10g数据库中,数据集中存在几何网络,在存在网络的情况下通过程序对其中的数据图层进行重命名,弹出"Th ...
- 第六章 springboot + 事务
在实际开发中,其实很少会用到事务,一般情况下事务用的比较多的是在金钱计算方面. mybatis与spring集成后,其事务该怎么做?其实很简单,直接在上一节代码的基础上在相应的方法(通常是servic ...
- 『BASH』——文件权限批量恢复脚本——「Permission Revovery」
一.恢复指定程序包所有文件的权限: #!/bin/bash #Assume that you have mounted a correct orignal-system on /mnt read -p ...
- JavaI/O系统
I/O:(输入/输出)指的是计算机与外部世界,或者一个与计算机其余部分的接口.它对任何计算机系统都非常关键. Java类库中有大量的类,帮助我们从不同的设备读取数据并保存或输出到不同的设备中. 这些类 ...
- URAL - 1920 Titan Ruins: the Infinite Power of Magic(乱搞)
搞死人的题目,,, 就是在n*n的方格中找路径长度为L的回路. 开始的思路值适合n为偶数的情况,而忽视了奇数的case,所以wa了一次. 然后找奇数case的策略,代码从70多行变成了100多,然后改 ...
- C3P0连接池异常
解决方案: 将c3p0.jar包换成c3p0-0.9.0.2.jar,c3p0这个包应该有bug 引用如下: com.mchange.v2.log.MLog Determines which libr ...
- 10 个超酷的加载中的 Gif 动画
#1: Calming cat loading gif #2: Stylish loading gif #3: Shape changing loading gif #4: Loading gif f ...
- http://www.cnbeta.com/articles/306769.htm
事实上,很少有方法可以帮你做到.有些人可能会想到试着把Vim打造成C语言IDE的,比如c.vim:也有把Vim集成到Eclipse里的Eclim .但是我想要告诉你的是一个更加通用的,只用插件实现的方 ...