要使用css对HTML页面中的元素实现一对一,一对多或者多对一的控制,这就需要用到CSS选择器。

一、通配符选择器

语法:*{ }

说明:通配符选择器可以选择页面上所有的html标签(包括body,html标签

用途:练习阶段清除页面所有标签的默认样式(使用通配符清除默认样式仅在练习阶段使用)

 <style>
* {
margin: ;
padding: ;
color: red;
background: lightblue;
}
</style>
<div>这是一个div</div>
<p>这是一个p标签</p>

效果:body区域的背景色渲染成了lightblue,div和p标签的字体颜色渲染成了红色

二、标签选择器

语法:标签名 {}

说明:通过html标签名选择标签设置样式,w3c也称作元素选择器或者类型选择器

用途:常用在某些标签的特殊样式 比如a、ul、ol等

 <style>
ul {
list-style: none;
}
a {
text-decoration: none;
color: red;
}
</style> <ul>
<li><a href="">链接</a></li>
<li><a href="">链接</a></li>
<li><a href="">链接</a></li>
</ul>  

效果:li的小圆点去掉和a标签的默认颜色改变

三、id选择器

语法:#id名:{}   (#号和id名紧挨着)

说明:通过标签的id名选择标签设置样式, 整个页面中只能有唯一一个id名

    用途:id优先级较高,有时候用来层叠掉某些类样式

 <style>
#dv {
width: 200px;
height: 200px;
background-color: lightblue;
color: orange;
}
</style>
<div id="dv">
这是一个div
</div>

效果:通过id选择器选择标签设置样式

四、类选择器

语法:.类名 {}   (由.和类名组成,.紧跟在类名前边,与id选择器类似)

说明:通过标签的类名选择到元素

用途:开发中最常用的选择器,不同的标签设置了同一个类名时,可以拥有相同的样式,当然一个标签也可以拥有多个类名。

 <style>
.common {
font-size: 18px;
color: orange;
}
.dv1 {
width: 200px;
height: 200px;
background-color: lightblue;
}
.dv2 {
border: 1px solid #ccc;
width: 200px;
height: 200px;
}
</style>
<div class="dv1 common">
这是div1
</div>
<div class="dv2 common">
这是div2
</div>

效果:两个div都拥有两个样式,且都引用了common样式,这时候div会把引用的类样式都渲染出来,我们通常把相同的样式提取出来

五、属性选择器

用法:[属性名] {}  ([]方括号内部直接写标签的属性名即可)

说明:希望选择有某个属性的元素,可以使用这种选择器,当然属性选择器还有其他用法。

<style>
[class] {
width: 200px;
height: 200px;
border: 1px solid black;
}
</style>
<div class="dv1">
这是div1
</div>
<div class="dv2">
这是div2
</div>

效果:具有class属性的标签都会渲染出相同的样式

标签选择器的其他用法(图表参考w3c)详细用法参考W3C

选择器 描述
[attribute] 用于选取带有指定属性的元素
[attribute=value] 用于选取带有指定属性和值的元素
[attribute~=value] 用于选取属性值中包含指定词汇的元素
[attribute|=value] 用于选取带有以指定值开头的属性值的元素,该值必须是整个单词
[attribute^=value] 匹配属性值以指定值开头的每个元素
[attribute$=value] 匹配属性值以指定值结尾的每个元素
[attribute*=value] 匹配属性值中包含指定值的每个元素

六、后代选择器

语法:每一层选择器用空格隔开

说明:后代选择器可以选择作为某元素后代的元素,不管后代标签再结构中嵌套多深,都会选择到

/*选中div后代中的p*/
div p {
color: red;
} 后代选择器不但可以选中儿子,还可以选中孙子等所有的后代元素。
/*会选中box中的h3*/
.box h3 {
font-size: 50px;
}
<div class="box">
<div>
<div>
<div>
<h3>我是多层嵌套的h3</h3>
</div>
</div>
</div>
</div>

七、子代选择器

语法:父元素选择器 > 子元素选择器 { }

  说明:选择标签的直接子元素,无法选择孙子及后代元素

 <style>
h1 > strong {
color: red;
}
</style>
<h1>This is <strong>very</strong> <strong>very</strong> important.</h1>
<h1>
This is <em>really <strong>very</strong></em> important.
</h1>

效果:第一个h1的strong会变颜色,第二个h1下的strong不会变颜色

子代选择器与后代选择器的区别:子代选择器只能选择直接子元素,选择范围较小。后代选择器可以选择子孙后代元素,选择范围较大。

八、相邻兄弟选择器

语法:元素选择器 + 元素选择器 {}   (两者为相邻元素,且有相同父元素)

说明:可选择紧接在另一元素后的元素,且二者有相同父元素

 <style>
.box {
height: 100px;
width: 100px;
background-color: red;
}
/*h1和div 都会有20px的margin-top值 */
h1,
div {
margin-top: 20px;
}
</style>
<h1>这里是标题</h1>
<div class="box">box中的内容</div>

九、交集选择器

说明:同时选中两个选择器都具有的元素

语法:连续书写选择器,不要添加任何空格(和后代选择器进行区分)

 <style>
p.para {
font-size: 50px;
color: red;
}
</style>
<p class="para">p</p>
<p>我是p <span class="para">特殊</span></p>

效果:会给第一个p标签中的内容添加样式,第二个p中的标签和内容都不会添加样式

交集选择器可以连续交集(选择器可以书写多个)如:  p.para.fs{}  能被选中的元素具有以下特点:是p标签且含有para 和 fs类样式

十、并集选择器  

  语法:逗号隔开每一个选择器

说明:同时设置多个选择器相同的样式

<style>
div, h3, p {
font-size: 50px;
color: red;
}
</style>
<div>div</div>
<h3>h3</h3>
<p>p标签</p>

效果:div,h3和p标签都会设置上样式,并集选择器中的单个选择器也可以使用类选择器,id选择器,属性选择器等。

十一、伪类选择器

说明:CSS 伪类用于向某些选择器添加特殊的效果,工作中用的不太多

用法:详见W3C,伪类选择器

十二、伪元素选择器

说明:CSS 伪元素用于向某些选择器设置特殊效果,before和after常用

用法:伪元素选择器

总结:以上内容几乎涵盖工作当中的所有用法,其中常用的有类选择器、标签选择器、id选择器、属性选择器、伪元素选择器的before和after,有些不常用的没有给出具体效果,可以根据提供的代码,自行实验

CSS汇总之CSS选择器的更多相关文章

  1. CSS系列:CSS选择器

    选择器(selector)是CSS中很重要的概念,所有HTML语言中的标记样式都是通过不同的CSS选择器来控制的.用户只需要通过选择对不同的HTML标签进行选择,并赋予各种样式声明,即可实现各种效果. ...

  2. CSS:CSS样式表及选择器优先级总结

    我们在写网页的时候经常会遇到同一个HTML文件,使用了外部样式.内部样式以及内联样式,那么如果发生冲突时浏览器是怎么抉择的呢? 也会遇到这样的情况,在样式表中,对同一个HTML元素,我们有可能既用到了 ...

  3. Html 之div+css布局之css选择器

    CSS选择器 什么叫选择器?通俗的来说就是 我想改变html 中某个地方的  字体大小 或者背景色 或者其它属性 内边距 外边距,宽度高度 等等 一些Css 样式. 那么我们如何找到对应的 元素呢? ...

  4. CSS选择器、CSS hack及CSS执行效率

    主要内容: 1.CSS选择器.优先级与匹配原理 2. CSS 引入的方式有哪些 ? link 和 @import 的区别是 ? 3.CSS hack 4.如何书高效CSS  一.CSS选择器.优先级与 ...

  5. CSS样式----图文详解:css样式表和选择器

    主要内容 CSS概述 CSS和HTML结合的三种方式:行内样式表.内嵌样式表.外部样式表 CSS四种基本选择器:标签选择器.类选择器.ID选择器.通用选择器 CSS三种扩展选择器:组合选择器.后代选择 ...

  6. [HTML] CSS Id 和 Class选择器

    id 和 class 选择器 如果你要在HTML元素中设置CSS样式,你需要在元素中设置"id" 和 "class"选择器. id 选择器 id 选择器可以为标 ...

  7. css笔记09:选择器优先级

    1. (1) <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www. ...

  8. CSS 选择器之基本选择器 属性选择器 伪类选择器

    CSS 选择器 常见的选择器列表图 CSS选择器笔记 基本选择器 通配符选择器(*) 元素选择器(E) 类选择器(.className)    所有浏览器都支持类选择器,但多类选择器(.classNa ...

  9. HTML+CSS Day05 基本CSS选择器、复合CSS选择器与CSS继承性

    1.基本CSS选择器 (1)标记选择器 <style>                       h1{ color:red; font-size:25px;}           &l ...

随机推荐

  1. 利用JVM在线调试工具排查线上问题

    在生产上我们经常会碰到一些不好排查的问题,例如线程安全问题,用最简单的threaddump或者heapdump不好查到问题原因.为了排查这些问题,有时我们会临时加一些日志,比如在一些关键的函数里打印出 ...

  2. MySQL 和 Navicat Premium 下载及安装全过程

    前言: 我对 “MySQL社区版” 的理解是:它只是一个后台服务,它的管理需要用到其他的数据库管理软件,这里我用的是 Navicat Premium,这个软件可以同时为多个数据库提供管理,比如MySQ ...

  3. 【TencentOS tiny】深度源码分析(4)——消息队列

    消息队列 在前一篇文章中[TencentOS tiny学习]源码分析(3)--队列 我们描述了TencentOS tiny的队列实现,同时也点出了TencentOS tiny的队列是依赖于消息队列的, ...

  4. Java BIO及实现

    发现日常学习过的知识不久就会遗忘,在此只是整理并记录一下学习笔记,做个回忆,并方便以后查阅,若有错误,欢迎指正 网络模型:TCP/IP网络模型是从OSI七层模型中演化来的,osi模型分为物理层,数据链 ...

  5. vue图片点击放大预览

    第一种:viewerjs使用介绍(PC.移动端都兼容) 1.先安装依赖 npm install v-viewer --save 2.main.js内引用并注册调用 //main.js import V ...

  6. Python历史+优缺点+应用领域+网站职位简介

    一.Python的历史 1. 1989年圣诞节:Guido von Rossum开始写Python语言的编译器.2. 1991年2月:第一个Python编译器(同时也是解释器)诞生,它是用C语言实现的 ...

  7. Spring源码分析之IOC的三种常见用法及源码实现(一)

    1.ioc核心功能bean的配置与获取api 有以下四种 (来自精通spring4.x的p175) 常用的是前三种 第一种方式 <?xml version="1.0" enc ...

  8. Linux之常用命令II

    一.VI编辑器 1) 概述 ◆  Visual Interface(可视化接口): ◆  类似Windows中的记事本,比记事本强大: ◆  VIM相对于VI做了哪些提升 -VIM支持多级撤销 -VI ...

  9. linux系统取证

    目录 0x00 查看系统信息 0x01 用户及组信息 0x02 防火墙及路由信息 0x03 查看网络.端口信息 0x04 系统运行信息查看 0x05 日志查看分析 0x00 查看系统信息 name-a ...

  10. 小白学 Python(7):基础流程控制(上)

    人生苦短,我选Python 前文传送门 小白学 Python(1):开篇 小白学 Python(2):基础数据类型(上) 小白学 Python(3):基础数据类型(下) 小白学 Python(4):变 ...