要使用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. 《构建之法》MSF&需求分析

    第七章 MSF MSF基本原则 推动信息共享与沟通 为共同的远景而工作 充分授权和信任 各司其职,对项目共同负责 交付增量的价值 保持敏捷,预期和适应变化 投资质量 学习所有的经验 与顾客合作 MSF ...

  2. 1046 Shortest Distance (20 分)

    1046 Shortest Distance (20 分) The task is really simple: given N exits on a highway which forms a si ...

  3. django搭建BBS-登入&验证码的生成

    django搭建BBS-登入&验证码的生成 基于注册完成后 文件结构 app 接口 migrations __inint__.py admin.py 管理员页面注册表单用 apps.py bb ...

  4. Java中Integer.parseInt和Integer.valueOf,你还傻傻分不清吗?

    在Java的Integer类中,有Integer.valueOf(String s)和Integer.parseInt(String s)两个静态方法,他们都能够将字符串转换为整型,他们到底有什么区别 ...

  5. Web前端助手-功能丰富的Chrome插件

    整合优秀的前端实用工具.免费,可配置的强大工具集 示例 安装 github仓库: https://github.com/zxlie/FeHelper 官网地址:https://www.baidufe. ...

  6. [插件化开发] Poc之后,我选择放弃OSGI

    Poc之后,我选择放弃OSGI TIPS: 如贵司允许重构老系统或者允许使用OSGI的第三方框架改造所带来的投入成本,并且评估之后ROI乐观,那么还是可以使用的. Runtime Version 以下 ...

  7. [NOIp2009] luogu P1071 潜伏者

    翘课间操和体育课来水博客. 题目描述 CCF的题面贼长,但貌似除了背景以外,每句话都删不掉.不写啦,反正也是Ctrl C的. Solution 显然这是一道码农题. #include<cstdi ...

  8. 一文了解Mysql

    文章原创于公众号:程序猿周先森.本平台不定时更新,喜欢我的文章,欢迎关注我的微信公众号. Redis系列到上一篇已经全部结束了,从本篇开始进入Mysql系列文章专题.本篇作为Mysql系列专题的开篇文 ...

  9. 事业单位招聘网搭建思路和seo方法

    期望目标 自动采集事业单位招聘信息+自动发布到网站+自动提交网址到百度+自动发外链. 技术框架 前端用layUI,后端用flask,数据库用的elasticsearch,编程语言用Python 3.7 ...

  10. Java获取文件中视频的时长

    public void ReadVideoTime(String path) { long sum = 0; long num = 0; File source = new File(path[i]) ...