前戏

前面我们说过CSS规则由选择器和声明组成,我们要给标签设置属性,那我们就要找到对应的标签,CSS选择器可以帮我们找到我们需要的标签

css选择器有:

标签选择器

类选择器

ID选择器

全局选择器

群组选择器

后代选择器

标签选择器

标签选择器前面我们用过,它是以HTML标签作为选择器

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
p{color:red}
h1,div{color:blue}
</style>
</head>
<body>
<h1>h1标签</h1>
<div>css选择器</div>
<p>标签选择器</p>
<p>类选择器</p>
<p>ID选择器</p>
</body>
</html>

注意:有多个标签之间用,隔开

类选择器

同一个元素可以设置多个类,之间用空格隔开

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
.p1{color:red}
.p2,.p3{color:blue} </style>
</head>
<body>
<h1 class="p1">h1标签</h1>
<div>css选择器</div>
<p class="p1">标签选择器</p>
<p class="p2">类选择器</p>
<p class="p3">ID选择器</p>
</body>
</html>

注意:多个类时用,隔开

如果我们只想给p标签下的class=p1的设置怎么办?

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
p.p1{color:red} </style>
</head>
<body>
<h1 class="p1">h1标签</h1>
<div>css选择器</div>
<p class="p1">标签选择器</p>
<p class="p2">类选择器</p>
<p class="p3">ID选择器</p>
</body>
</html>

在类选择器前面加上标签名就可以了

ID选择器

id选择器和类选择器差不多,类选择器用的是点,id选择器用的是#

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
#i1{color: green} </style>
</head>
<body>
<p id="i1">标签选择器</p>
<p id="i2">类选择器</p>
<p id="i3">ID选择器</p>
</body>
</html>

群组选择器

群组选择器其实我们在标签选择器的时候已经使用过了,就是把多个标签用逗号隔开,当然,群组选择器不只可以用做标签,也可以用做类选择器,id选择器

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
#i1,#i2,#i3,.h1{color: red} </style>
</head>
<body>
<h1 class="h1">我是h1</h1>
<p id="i1">标签选择器</p>
<p id="i2">类选择器</p>
<p id="i3">ID选择器</p>
</body>
</html>

这样,页面上所有的字体都成了红色

全局选择器

全局选择器就是给所有标签设置一个样式,一般用做清除标签默认的样式

我们来将上面的群组选择器换成全局选择器

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
*{color: red} </style>
</head>
<body>
<h1 class="h1">我是h1</h1>
<p id="i1">标签选择器</p>
<p id="i2">类选择器</p>
<p id="i3">ID选择器</p>
</body>
</html>

后代选择器

使用后代选择器,之间用空格隔开

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
p em {color: red} </style>
</head>
<body>
<h1 class="h1"><em>明天</em>我是h1</h1>
<p ><em>今天</em>标签选择器</p>
<p id="i2">类选择器</p>
<p id="i3">ID选择器</p>
</body>
</html>

这样写我们就给p标签下面的em标签加上了颜色

后代选择器可以写多层

伪类选择器

链接伪类

链接也就是a标签,有四种状态:激活状态,已访问状态,未访问状态,和鼠标悬停状态

伪类hover和active

上面的四种状态的:link和:visited是a标签专用的,而:hover和:active其他标签也可以使用

:hover用与访问的鼠标经过某个元素时

:active用于一个元素被激活时(既按下鼠标之后松开鼠标之前的时间)

<!DOCTYPE html>
<html lang="en">
<head>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8"/>
<style>
a:link{color: blue}/*未访问状态*/
a:visited{color: gray}/*已访问状态*/
a:hover{color:red}/*鼠标悬浮状态*/
a:active{color: green}/*鼠标激活状态*/
p:hover{color:red}
p:active{color: green} </style>
</head>
<body>
<a href="https://cn.bing.com/">必应</a>
<p id="i2">类选择器</p> </body>
</html>
链接伪类的顺序

:link>:visited>:hover>:active

说明:

  a:hover必须置于a:link和a:visited之后才有效

  a:active必须置于a:hover之后才有效

CSS优先级

同一样式表中:

1.权值相同,就近原则(离被设置元素越近优先级越高)

2.权值不同,根据权值来判断css样式,哪种权值高,就使用哪种样式

选择器权值

标签选择器,权值为1

类选择器和伪类,权值为10

id选择器,权值为100

通配符选择器,权值为0

行内样式,权值为1000

权值规则

统计不同选择器的个数

每类选择器的个数乘以相应的权值

把所有的值想加得出选择器的权值

!important规则

可调整样式规则的优先级

添加在样式规则之后,中间用空格隔开

CSS样式命名

采用英文字母,数字以及”-“和”_“命名

以小写字母开头,不能以数字、”-“,"_"开头

命名形式:单字,连字符,下划线和驼峰

css--css选择器,伪类的更多相关文章

  1. 前端 CSS的选择器 伪类选择器

    伪类选择器 常用的几种伪类选择器. 伪类选择器一般会用在超链接a标签中 没有访问的超链接a标签样式: a:link { color: blue; } <!DOCTYPE html> < ...

  2. 前端 CSS的选择器 伪类选择器 CSS3 nth-child()

    first-child 选中第一个标签 应用CSS样式 <!DOCTYPE html> <html lang="en"> <head> < ...

  3. python 全栈开发,Day47(行级块级标签,高级选择器,属性选择器,伪类选择器,伪元素选择器,css的继承性和层叠性,层叠性权重相同处理,盒模型,padding,border,margin)

    一.HTML中的行级标签和块级标签 块级标签 常见的块级标签:div,p,h1-h6,ul,li,dl,dt,dd 1.独占一行,不和其他元素待在同一行2.能设置宽高3.如果不设置宽高,默认为body ...

  4. CSS 基础知识点 样式 选择器 伪类

    CSS 基础知识点汇集 版权声明:这篇博客是别人写的,大神博客地址 : https://www.cnblogs.com/Mtime/p/5184685.html 1.CSS 简介 CSS 指层叠样式表 ...

  5. CSS属性、伪类选择器,CSS3选择器

    CSS1时IE6是部分支持,伟大的IE6!CSS2时IE6部分支持,伟大的IE6依旧是部分支持!CCS3盛行CSS4也已经提上日程的现在,IE6完全不支持.IE6你该走了,我们会永远记住你的功绩的!I ...

  6. CSS Pseudo-classes(伪类)

    CSS Pseudo-classes(伪类) CSS伪类是用来添加一些选择器的特殊效果. 一.语法 伪类的语法: selector:pseudo-class {property:value;} CSS ...

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

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

  8. css 为元素选择器,css目标状态伪类,结构化选择器,多媒体选择器,清除表默认样式、属性选择器

    伪元素选择器 :before 和 :after 添加的位置 :before --- 第一个子节点 :after --- 最后一个子节点 特点 1.默认是 inline 元素 2.必须包含 conten ...

  9. CSS选择器之伪类选择器(伪元素)

    selection [CSS4]应用于文档中被用户高亮的部分(比如使用鼠标或其他选择设备选中的部分).(IE8及以下不支持)(火狐-moz-selection) first-line 选择每个 < ...

  10. CSS选择器之伪类选择器(交互)

    :link 选取未访问链接 :active 选取活动链接(单击某链接,未松开鼠标时). :visited 选取已被访问的链接. :target 链接指定的目标 :hover 当鼠标浮在元素上方时. : ...

随机推荐

  1. k8s-基于canel的网络策略-十九

    一.前提 上一节学习了flannel,但是我们应该了解flannel只能提供网络通讯,而不能提供网络策略.因此,我们本节学习canal,让它来提供网络策略,来配合flannel使用. canal是ca ...

  2. linux mplayer 播放yuv格式 (转载)

    转自:http://blog.csdn.net/ly0303521/article/details/38713791 在mplayer中查看YUV格式的图片或视频,可使用如下命令: mplayer - ...

  3. J20170426-hm

    ジェネリクス Generics 泛型 バルーン balloon 气球 アングルブラケット Angle bracket 尖括号 プレースホルダ Placeholder 占位符

  4. poj 1733 Parity game【hash+带权并查集】

    hash一下然后用带权并查集做模2下的前缀和 #include<iostream> #include<cstdio> #include<map> #include& ...

  5. P4141 消失之物(背包)

    传送门 太珂怕了……为什么还有大佬用FFT和分治的…… 首先如果没有不取的限制的话就是一个裸的背包 然后我们考虑一下,正常的转移的话代码是下面这个样子的 ;i<=n;++i) for(int j ...

  6. (三)SpringBoot定义统一返回result对象

    一:定义响应码枚举 package com.example.demo.core.ret; /** * @Description: 响应码枚举,参考HTTP状态码的语义 * @author * @dat ...

  7. C++ multiset通过greater、less指定排序方式,实现最大堆、最小堆功能

    STL中的set和multiset基于红黑树实现,默认排序为从小到大. 定义三个multiset实例,进行测试: multiset<int, greater<int>> gre ...

  8. SQL - nulls值排序问题

    给字段排序时遇到的null值问题 当我们使用order by来为指定的字段进行排序时,如果db中该字段的值存在着null值,那么在排序时这些null值会不会参与排序呢?如果参与排序的话,又是以怎样的标 ...

  9. WIN7 X64的运行命令窗口

    要在WIN7系统下用界面的方式执行运行命令,则可以用如下两种方法方法打开运行对话框.1.点Win+R(run)就能出来的.2.在开始菜单上点右键,选“属性”,进入开始菜单属性设置界面,单击底部的“自定 ...

  10. 【Ajax】接收后台数据在html页面显示

    Java代码 PrintWriter out=response.getWriter(); //向客户端发送字符数据 response.setContentType("text/text&qu ...