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 中得到了很好拓展.本文将会比较全面的介绍属性选择器,尽可能的去挖掘这个选择器在不同场 ...
随机推荐
- Oracle相关账户几个语句
Oracle安装完成后,在“开始”里找到SQL Plus运行,要求输入帐号和密码,用system/密码连接. 1.Oracle里有一个默认的scott账户密码tiger,用该账户连接: CONN 用户 ...
- VS发布网站详细步骤
1.打开你的VS2012网站项目,右键点击项目>菜单中 重新生成一下网站项目:再次点击右键>发布: 2.弹出网站发布设置面板,点击<新建..>,创建新的发布配置文件: 输入你自 ...
- python学习之路-day1-python基础1
本节内容: Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc是个什么鬼? 数据类型初识 数据运算 表达式if ...else ...
- js 页面值变动监听
1.初始化值map对象 var compareMap = {}:// 定义全局变量 function initCompareMap(context){//context 为指定要初始化的区域,即上下文 ...
- 下载python标准库--python
#coding:utf-8 import urllib2 import os,sys from BeautifulSoup import BeautifulSoup # For processing ...
- [Chapter 3 Process]Practice 3.9 Describe the actions token by a kernel to content-switch between processes.
3.9 Describe the actions token by a kernel to content-switch between processes. 答案: 内核在进行进程上下文切换时, 首 ...
- 对IEnumerable<T>和IQueryable<T>的一点见解
今天学习了用EF模型做查询,感觉数据库上下文对象的扩展方法很强大,所以研究了一下where的实现原理,其中遇到了一个问题,就是关于IEnumerable和IQueryable的区别,所以查了查资料,这 ...
- 嵌入式linux自动登录
最近又把同事的fl2440板子拿过来跑了起来,没有太大收获,就解决了一个自动登录的问题: ::respawn:/sbin/getty -L ttySAC0 115200 vt100 -n root - ...
- Java集合框架面试题
www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 这里的两个图很形象,由于放进图片链接,图片显示不了,所以只能给出该链接. Java集合框架 ...
- Java 7新方法probeContentType的C#实现方式
在Java 7中增加了新的一个方法——probeContentType,其主要作用是可以判断文件的content type.相应代码如下所示: import java.io.IOException; ...