CSS选择器(CCS第三版)
什么是选择器?
CSS选择器就是使样式找到应用对象。
简单选择器(Simple selectors)
在日常开发中,最常用的选择器,也是最基本的选择器。
元素选择器(Type selector)
针对HTML元素的选择器,用于寻找指定的HTML元素。
a { color: blue; }
p { color: black; }
通用选择器(Universal Selector)
通用选择器可设置全部的HTML元素,由一个 * 表示。
* { margin: 0; }
属性选择器(Attribute presence and value selectors)
| 类型 | 描述 |
|---|---|
[title] |
选择具有 title 属性的所有元素。 |
[title="baidu"] |
选择具有 title 属性且值为"baidu"的所有元素。 |
[title~="baidu"] |
选择 title 属性值中出现的一个用空格分隔的"baidu"的元素。 |
[title^="baidu"] |
选择 title 属性值以 "baidu" 开头的所有元素。 |
[title$="baidu"] |
选择 title 属性值以 "baidu" 结尾的所有元素。 |
[title*="baidu"] |
选择 title 属性值中包含字串"baidu"的所有元素。 |
以及[title|="baidu"]:选择 title 属性值中等于 "baidu"或以 "baidu-"开头的所有元素。
类选择器(Class Selectors)
给HTML元素中指定了 class 的元素定义样式。使用 . 表示。
.large-text { font-size: 18px; }
ID选择器(ID Selectors)
给HTML元素中指定了 id 的元素定义样式。使用 # 表示。
#main-content { margin: 8px; }
组选择器(Groups of selectors)
将具有相同的样式的元素,归为组合来写。使用 , 表示。
h1 { font-family: sans-serif }
h2 { font-family: sans-serif }
h3 { font-family: sans-serif }
等于
h1, h2, h3 { font-family: sans-serif }
伪类选择器(Pseudo-Classes)
伪类选择器是需要根据文档结构之外的其他条件对元素应用样式。使用 : 表示伪类选择器。
a:hover{ color: red }
伪类选择器包含两种:状态伪类和结构伪类。
状态伪类
基于HTML元素当前状态进行选择的。在与用户的交互过程中元素的状态是动态变化的,因此该元素会根据其状态呈现不同的样式。当元素处于某状态时会呈现该样式,而进入另一状态后,该样式也会失去。
| 属性 | 描述 | css版本 |
|---|---|---|
:link |
匹配未被访问的链接的元素。(标签) | 1 |
:visited |
匹配已被访问的链接的元素。(标签) | 1 |
:active |
匹配被激活的元素。(如鼠标点击的瞬间) | 1 |
:hover |
当鼠标悬浮在元素上方时,向元素添加样式。 | 2 |
:focus |
匹配拥有键盘输入焦点的元素。 | 2 |
:target |
匹配相关URL指向的E元素。 | 3 |
:checked |
匹配处于选中状态的元素添加样式。(用于input type为radio与checkbox时) | 3 |
:enabled |
向处于可用状态的元素添加样式。 | 3 |
:disabled |
向处于禁用状态的元素样式。 | 3 |
:indeterminate |
表示状态不确定的表单元素。(用于input type为radio与checkbox及<progress>时) | 3 |
结构伪类
结构性伪类是css3新增选择器,利用dom树进行元素过滤,通过文档结构的互相关系来匹配元素,能够减少class和id属性的定义,使文档结构更简洁。
| 属性 | 描述 | css版本 |
|---|---|---|
:not(s) |
匹配不含有s选择符的元素。 | 3 |
:first-child |
匹配父元素的第一个子元素E。 | 2 |
:last-child |
匹配父元素的最后一个子元素E。 | 3 |
:only-child |
匹配父元素仅有的一个子元素E。 | 3 |
:nth-child(n) |
匹配父元素的第n个子元素E。 | 3 |
:nth-last-child(n) |
匹配父元素的倒数第n个子元素E。 | 3 |
:first-of-type |
匹配同类型中的第一个同级兄弟元素E。 | 3 |
:last-of-type |
匹配同类型中的最后一个同级兄弟元素E。 | 3 |
:only-of-type |
匹配同类型中的唯一的一个同级兄弟元素E。 | 3 |
:nth-of-type(n) |
匹配同类型中的第n个同级兄弟元素E。 | 3 |
:nth-last-of-type(n) |
匹配同类型中的倒数第n个同级兄弟元素E。 | 3 |
:empty |
匹配没有任何子元素(包括text节点)的元素。 | 3 |
:root |
匹配文档根元素。 | |
| 在HTML中,根元素始终是<html>。 | 3 |
其他伪类及相关信息请参考:
伪类
各伪类实现(待完成...)
伪元素选择器(Pseudo-elements)
伪元素是对元素中的特定内容进行操作,而不是描述状态。它的操作层次比伪类更深一层,因此动态性比伪类低很多。实际上,伪元素就是选取某些元素前面或后面这种普通选择器无法完成的工作。控制的内容和元素是相同的,但它本身是基于元素的抽象,并不存在于文档结构中!
使用 :: 表示伪元素选择器。
| 属性 | 描述 | css版本 |
|---|---|---|
::first-letter |
向文本的第一个字母添加特殊样式。 | 1 |
::first-line |
向文本的首行添加特殊样式。 | 1 |
::before |
在元素之前添加内容。 | 2 |
::after |
在元素之后添加内容。 | 2 |
::before 和 ::after
::before 和 ::after 被引入CSS中,最核心的目的,还是为了实现语义化。
使用::before 和 ::after 布局的闭合问题
.clear::after {
content: '';
display: block;
clear: both;
}
组合选择器
后代选择器(Descendant combinator)
由于HTML元素之间具有层次结构关系,因此在一些情况下,我们需要根据对应的HTML结构寻找指定的HTML元素。
p span{ color: #999; }
ul li { font-size:14px; }
#main-content div { color: black; }
子选择器(Child combinators)
选择元素的直接子元素。使用 > 表示。
body > div {
background: #c0c0c0;
height: 100px;
width: 100%;
}
body > div > div {
background: red;
}
相邻选择器(Next-sibling combinator)
根据一个元素与另一个元素的相邻关系对它应用样式。使用 + 表示。
/* 相邻元素选择后面的元素进行样式设置 */
li + li {
border-left: 1px solid #000000;
}
一般兄弟选择器(Subsequent-sibling combinator)
根据一个元素在另外一个元素后面且两个元素都属于一个父元素,对后面选择的元素进行样式设置。使用 ~ 表示。
/* 选择后面的元素进行样式设置 */
p ~ span {
color: red;
}
选择器层叠和特殊性
当你随机打开一个页面,查看源代码,你会发现,同一个元素,不止有一个CSS选择器及对应的样式。而一个元素只能应用一个样式,那么一堆样式中究竟是应用哪一个呢?这就涉及到CSS的层叠规则了。
CSS层叠规定了选择器的特殊性,将特殊性分为a,b,c,d四个登记,各等级特殊性逐渐降低(即a>b>c>d)。通过选择器特殊性的比较,实现样式选择。
计算规则如下:
- 在
style中写的内联样式或加!important的样式特殊性为 1,0,0,0 (!important> 内联样式) - 每个ID选择器的特殊性为 0,1,0,0
- 每个类、伪类或者属性选择器的特殊性为 0,0,1,0
- 每个元素或伪元素选择器贡献特殊性为 0,0,0,1
- 组合选择器和通配符的对特殊性没有贡献
用style属性编写的规则总是比其他任何规则特殊;具有ID选择器的规则比没有ID选择器的规则特殊;具有类选择器的规则比只有类型选择器的规则特殊;如果两个规则的特殊性相同,那么后定义的规则优先。
参考
CSS选择器(CCS第三版)的更多相关文章
- CSS权威指南-第三版--读书笔记
第一章:CSS和文档 html是结构化语言,css是样式语言,html主要用来被强大的搜索引擎更好的索引,更好的让一个盲人通过语音浏览器来了解我们的网页,这也就是为什么说html是结构话语言,因为这是 ...
- (转)css选择器及其优先级
文章主要介绍什么是CSS选择器,CSS选择器的分类以及CSS选择器的优先级三部分内容,希望能够帮助到正在学习CSS的童鞋,有什么不足的地方欢迎大家批评指正. 一.什么是CSS选择器? CSS选择器又被 ...
- CSS选择器有哪几种?举例轻松理解CSS选择器
CSS选择器汇总(清爽版) 1.元素选择器 标签名{ } 2.id选择器 #id属性值{ } 3.类选择器 ·class属性值{ } 4.选择器分组(并集选择器) 作用:通过它可以同时选中多个选择器对 ...
- 后端码农谈前端(CSS篇)第三课:选择器
一.选择器 1.ID选择器: 语法:首先,ID 选择器前面有一个 # 号 - 也称为棋盘号或井号.请看下面的规则: *#intro {font-weight:bold;} 与类选择器一样,ID 选择器 ...
- 第三百四十节,Python分布式爬虫打造搜索引擎Scrapy精讲—css选择器
第三百四十节,Python分布式爬虫打造搜索引擎Scrapy精讲—css选择器 css选择器 1. 2. 3. ::attr()获取元素属性,css选择器 ::text获取标签文本 举例: extr ...
- HTML中放置CSS的三种方式和CSS选择器
(一)在HTML中使用CSS样式的方式一般有三种: 1 内联引用 2 内部引用 3 外部引用. 第一种:内联引用(也叫行内引用) 就是把CSS样式直接作用在HTML标签中. <p style ...
- 学习《CSS选择器Level-4》不完全版
1 概述 1.1 前言 选择器是CSS的核心组件.本文依据W3C的Selectors Level 4规范,概括总结了Level1-Level4中绝大多数的选择器,并做了简单的语法说明及示例演示.希望对 ...
- CSS权威指南(第三版)
CSS权威指南(第三版).pdf 网盘: https://545c.com/file/24657411-425141851 获取码: 276922
- css考核点整理(三)-css选择器的使用
css选择器的使用
随机推荐
- centos6.9 安装mysql8
centos6.9 安装 mysql8 # 安装mysql8 1.下载https://cdn.mysql.com//Downloads/MySQL-8.0/mysql-8.0.16-2.el6.x86 ...
- re库的使用
re库的使用 精确匹配 如果直接给出字符,就是精确匹配.用\d可以匹配一个数字,\w可以匹配一个字母或数字 s1='00\d'#可以匹配'007',但是匹配不了'00A' s2='\d\d\d'#可以 ...
- 环境变量和Path环境变量
环境变量 百度百科下的定义 一般是指在操作系统中用来指定操作系统运行环境的一些参数,如:临时文件夹位置和系统文件夹位置等. 环境变量是在操作系统中一个具有特定名字的对象,它包含了一个或者多个应用程序所 ...
- 并查集专题: HDU1232畅通工程
畅通工程 Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Total Submi ...
- PHP实现支付宝小程序用户授权的工具类
背景 最近项目需要上线支付宝小程序,同时需要走用户的授权流程完成用户信息的存储,以前做过微信小程序的开发,本以为实现授权的过程是很简单的事情,但是再实现的过程中还是遇到了不少的坑,因此记录一下实现的过 ...
- PY个快速模
既然这道题是数学题,那就用 PY 吧! 学点东西: print 可以和 c++ 中的 printf 一样快乐的输出格式 另外一点: 这道题可能数据不够强?想想应该有一个 \(0^0 ~\%~ k =0 ...
- BZOJ 5317: [Jsoi2018]部落战争
传送门 写出式子,若存在 $a \in A$,$b \in B$,使得 $b+v=a$,那么此方案会产生冲突 即存在 $a \in A$,$b \in B$,使得 $v=a+(-b)$,设 $C=A+ ...
- 【已解决】Error running 'xxx项目' Command line is too long(idea版)
[错误] Error running 'xxx项目': Command line is too long. Shorten command line for xxx or also for Sprin ...
- 自我笔记,Rides介绍
Redis是一个key-value存储系统,和Memccached类似,支持存储的value类型相对更多,很大程度上补偿memcached这类key-value存储的不足 他提供了Java,c/c++ ...
- PHP支付宝手机网站支付功能
1.开通支付宝商家中心里面的手机网站支付 2.再去开放平台-开发者中心-创建移动支付的应用-获取到APPID 3.接着去文档中心下载DEMO 其实demo很简单.如果第一次看的话会存在看不懂的状态. ...