CSS选择器类型总结
CSS选择器类型总结
1.通用选择器
一般用于给所有元素做一些通用性的样式设置,比如清除内边距、外边距等。但是效率比较低,尽量不要使用。
* {
margin: 0;
padding: 0;
}
2.元素选择器
也叫做“标签选择器”,用于选中一类标签进行样式设置。
div { color: #ff0000; }
span { font-size: 18px; }
3.类选择器
给元素添加class属性,通过
.class属性值来选中元素。
- 一个元素可以有多个class值,每个class值之间用空格隔开;
- class值如果由多个单词组成,单词之间可以用
中划线-、下划线_,也可以使用驼峰标识; - 最好不要用标签名作为class值;
.box {
width: 100px;
height: 100px;
background-color: #ff0000;
}
<div class="box"></div>
4.id选择器
给元素添加id属性,通过
#id属性值来选中元素。
- 一个HTML文档里面的id值是唯一的,不能重复;
- id值如果由多个单词组成,单词之间可以用
中划线-、下划线_,也可以使用驼峰标识; - 最好不要用标签名作为id的值;
#container { color: #ff0000; }
<div id="container"></div>
5.属性选择器
[attr]:选中拥有attr属性的元素;/* 选中拥有title属性的元素 */
[title]: { color: #ff0000; }
<div title="one">内容</div>
[attr=val]:选中attr属性值恰好等于val的元素;/* 选中title值恰好等于one的元素 */
[title="one"] { color: #ff0000; }
<div title="one">内容</div>
[attr*=val]:选中attr属性值包含单词val的元素;/* title属性值包含单词one的元素 */
[title*="one"] { color: #ff0000; }
<div title="one">内容1</div>
<p title="aaaone">内容2</p>
<span title="one-two">内容3</span>
[attr^=val]:选中attr属性值以val开头的元素;/* title属性值以单词one开头的元素 */
[title^="one"] { color: #ff0000; }
<div title="one">内容1</div>
<span title="one-two">内容2</span>
<p title="one two">内容3/p>
[attr|=val]:选中attr属性值恰好等于val或以单词val开头后面紧跟连字符-的元素;/* title属性值恰好等于one或者以单词one开头且后面跟着连字符-的元素 */
[title|="one"] { color: #ff0000; }
<div title="one">内容1</div>
<span title="one-two">内容2</span>
[attr~=val]:选中attr属性值包含单词val的元素(单词之间必须用空格隔开);/* title属性值包含单词one的元素(单词one与其他单词之间必须用空格隔开) */
/* 效果类似于类选择器 */
[title~="one"] { color: #ff0000; }
<div title="one">内容1</div>
<p title="one two">内容2</p>
[attr$=val]:选中attr属性值以单词val结尾的元素;/* title属性值以单词one结尾的元素 */
[title$="one"] { color: #ff0000; }
<div title="two-one">内容1</div>
<p title="two one">内容2</p>
6.后代选择器
选择指定元素下的子元素,包括直接和间接子元素,使用空格进行隔开。
/* 选择div下所有span元素 */
div span { color: #ff0000; }
<div>
<span>文字内容1</span>
<p>
<span>文字内容2</span>
</p>
</div>
7.子代选择器
选择指定元素下的直接子元素,不包括间接子元素,使用
>。
/* 选择div元素下的直接span元素 */
div > span { color: #ff0000; }
<div>
<span>文字内容1</span>
</div>
8.兄弟选择器
相邻兄弟选择器
+:选择某元素后面紧挨的兄弟元素;/* div元素后面紧挨的p元素 */
div + p { color: #ff0000; }
<div></div>
<p>内容</p>
全兄弟选择器
~:选择某元素后面的兄弟元素,不需要紧挨;/* div元素后面的p元素 */
div ~ p { color: #ff0000; }
<div></div>
<p>内容1</p>
<p>内容2</p>
9.交集选择器
选择同时符合多个条件的元素。
/* 选择div元素且class为one的 */
div.one { color: #ff0000; }
/* 选择div元素且class为one且title属性值等于one的 */
div.one[title="one"] { color: #ff0000; }
<div class="one" >内容1</div>
<div class="one" title="one">内容2</div>
10.并集选择器
不同选择条件,中间用
,连接,进行全部选中。
/* 所有的div元素 + 所有class值有one的元素 + 所有title属性值等于one的元素 */
div, .one, [title="one"] { color: #ff0000; }
<div>内容1</div>
<span title="one">内容2</span>
<p class="one">内容3</p>
11.伪类选择器
11.1.动态伪类
:link:a:link未访问的链接;:visited:a:visited已访问的链接;:hover:a:hover鼠标移动到链接上;:active:a:active激活的链接(鼠标在链接上长按未松开);:focus:当前拥有输入焦点的元素(能接收键盘的输入,一般为input);
注意点:
:hover必须放在:link和:visited后面才能完全生效;:active必须放在:hover后面才能完全生效;- 建议编写顺序:link、visited、focus、hover、active;
- 处理a元素,
:hover和:active也能用于其他元素;
11.2.目标伪类和语言伪类
目标伪类:
:target;语言伪类:
:lang;
11.4.元素状态伪类
:enabled:可用的;:disable:禁用的;:checked:选中的;
11.5.结构伪类
:nth-child(n):父元素中的第n个子元素(n代表任意正整数和0,也可用even(偶数)和odd(奇数));/* 选中所有父元素下的第一个为p的元素 */
p:nth-child(1) { color: #ff0000; }
:nth-last-child(n):与:nth-child相反,父元素中倒数第n个子元素;/* 选中父元素下倒数第一个为p的元素 */
p:nth-last-child(1) { color: #ff0000; } /* 选中最后两个为p的元素 */
p:nth-last-child(-n + 2) { color: #ff0000; }
nth-of-type(n):计数时只计算同种类型的元素;/* 选中父元素下所有p元素中的第二个p元素 */
p:nth-of-type(2) { color: #ff0000; }
:nth-last-of-type(n):从后往前计算同种类型的元素;/* 选中父元素下所有p元素中倒数第二个p元素 */
p:nth-last-of-type(2) { color: #ff0000; }
:first-child:等同于:nth-child(1);:last-child:等同于:nth-last-child(1);:first-of-type:等同于:nth-of-type(1);:last-of-type:等同于:nth-last-of-type(1);:only-child:是父元素中唯一的子元素;:only-of-type:是父元素中唯一的指定类型的元素;:empty:里面完全空白的元素,不包含子元素和内容;:root:根元素,就是html元素;
11.6.否定伪类
:not()的格式是:not(x)表示除x以外的元素(x表示简单的选择器,可以是元素、通用、属性、类、id、伪类(除否定伪类)选择器等)。
/* 选中父元素下所有p元素不是第一个和最后一个的p元素 */
p:not(:first-of-type):not(:last-of-type) { color: #ff0000; }
注意::not()只支持简单选择器,不支持组合选择器,比如交集和并集选择器等。
CSS选择器类型总结的更多相关文章
- 第二天(CSS 选择器)
1.常用的CSS选择器 类型选择器: 例如: p { color : red ; } 后代选择器: 例如: h2 span { font-weight : bold ; ...
- css格式比较及选择器类型总结
在前端入门的前三天把网页制作过程中常用的一些标签和属性都认识和练习了一遍,能够做出简单模块的框架.就像老师说的网页制作就像建一栋大楼,html是砖和水泥,css是精装,js是完善各个功能.现在就开始进 ...
- css选择器
常用css选择器,希望对大家有所帮助,不喜勿喷. 1.*:通用选择器 * { margin: 0; padding: 0; } 选择页面上的全部元素,通常用于清除浏览器默认样式,不推荐使用. 2.#i ...
- CSS选择器的权重与优先规则?
我们做项目的时候,经常遇到样式层叠问题,被其他的样式覆盖,或者写的权重不高没效果,对权重没有具体的分析,做了一个总结. css继承是从一个元素向其后代元素传递属性值所采用的机制.确定应当向一个元素应用 ...
- CSS系列:CSS选择器
选择器(selector)是CSS中很重要的概念,所有HTML语言中的标记样式都是通过不同的CSS选择器来控制的.用户只需要通过选择对不同的HTML标签进行选择,并赋予各种样式声明,即可实现各种效果. ...
- 细说CSS选择器
众所周知,CSS的一个核心特征就是能向文档中的一组元素类型应用某些规则.每个规则都有两个基本部分:选择器(selector)和声明块(declaration block).下图显示了规则的各个部分. ...
- CSS选择器详解
选择器是CSS的核心,从最初的元素.class/id选择器,演进到伪元素.伪类,以及CSS3中提供的更丰富的选择器,定位页面上的任意元素开始变得愈发的简单. 1.元素选择器 这是最基本的CSS选择器, ...
- CSS和CSS选择器
一:CSS CSS有三种书写形式(优先级从高到低) 1)行内样式:(内联样式)直接在标签style属性中书写 2)内页样式:在本网页的style标签中书写 3)外部样式:在单独的CSS文件中书写,然后 ...
- CSS 选择器(转)
原文转自:http://www.cnblogs.com/xyzhanjiang/p/5447406.html CSS 选择器除了样式表匹配元素时需要用到,在使用 jQuery 等库的时候也可以利用 C ...
随机推荐
- 阿里云服务器的MySQL连接和vscode远程连接
目录 一.前言 二.使用Navicat等软件连接MySQL 1. 修改服务器系统密码 2. 防火墙选项添加MySQL 3. 使用Navicat连接 三.使用vscode连接服务器 一.前言 双十一的时 ...
- Lilypond+TexLive(LuaLatex+lyluatex)+VS Code实现谱文混排
没想到发文章反而更难被预览了,那就复制一份到随笔里好了. 多次尝试之下,终于实现了现阶段谱文混排的最理想方式: 1. 综合Latex的排版(还有广泛适用人群)的优势以及Lilypond的美观优势: 2 ...
- 撸了一个可调试 gRPC 的 GUI 客户端
前言 平时大家写完 gRPC 接口后是如何测试的?往往有以下几个方法: 写单测代码,自己模拟客户端测试. 可以搭一个 gRPC-Gateway 服务,这样就可以在 postman 中进行模拟. 但这两 ...
- vue2项目中引用外部js文件
vue2项目目录如下(utils文件夹是自己手工建的,然后在utils里新建js文件): 使用import导入文件时,注意路径,路径不对会报错: 导入之后使用外部js函数时,直接写导入时的名字加小括号 ...
- uniapp如何在当前页面获取上个页面的变量、方法
getCurrentPages() getCurrentPages() 函数用于获取当前页面栈的实例,以数组形式按栈的顺序给出,第一个元素为首页,最后一个元素为当前页面. 注意: getCurrent ...
- Linux远程软件
Xhell6:Linux的终端模拟软件 1>安装并破解:解压.破解(运行两个.bat文件).启动(点击Xshell.exe文件) 2>连接远端Linux系统: 创建会话:点击连接,在常规框 ...
- SAM 感性瞎扯
SAM 做题笔记. 这里是 SAM 感性瞎扯. 最近学了后缀自动机(Suffix_Automaton,SAM),深感其巧妙之处,故写文以记之. 部分文字与图片来源于 OI-Wiki,hihoCoder ...
- 【GS文献】基因组选择技术在农业动物育种中的应用
中国农业大学等多家单位2017年合作发表在<遗传>杂志上的综述,笔记之. 作者中还有李宁院士,不胜唏嘘. 1.概述 GS的两大难题:基因组分型的成本,基因组育种值(genomic esti ...
- 【机器学习与R语言】7-回归树和模型树
目录 1.理解回归树和模型树 2.回归树和模型树应用示例 1)收集数据 2)探索和准备数据 3)训练数据 4)评估模型 5)提高模型性能 1.理解回归树和模型树 决策树用于数值预测: 回归树:基于到达 ...
- Linux—yum安装python-pip
centos下安装pip时失败: [root@wfm ~]# yum -y install pipLoaded plugins: fastestmirror, refresh-packagekit, ...