前戏

前面我们说过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. Javaweb中利用kaptcha生成验证码

    引入kaptcha-2.3-jdk15.jar包 在web.xml中进行配置 <servlet> <servlet-name>Kaptcha</servlet-name& ...

  2. excel的部分使用方法

    第一行数据填充下面所有行的快捷键,ctrl+d 两个表关联替换:=VLOOKUP(H1576,Sheet3!$B$2:$C$315,2,0) 取消下拉框:数据>数据有效性>全部清除 快捷选 ...

  3. display:inline-block的div 与 display:block的div之间有间隔问题(div与div之间有间隔的可能性)

    首先看一下我出现的问题如下图: 如上图所示,我的导航栏是由三部分组成的,三部分样式如下: .logo{ /*红框*/ position: relative; display: inline-block ...

  4. const 和 constexpr

    在C++中,const 这个关键字用法非常灵活,导致我总会搞不清作用是干啥的.灵活使用const会大大改善程序. const 是C++的一种类型修饰符,是不可改变的不能被更新的. 1.const 修饰 ...

  5. Codeforces Round #544 (Div. 3) A.Middle of the Contest

    链接:https://codeforces.com/contest/1133/problem/A 题意: 给两个时间点,求中间时间点. 思路: 数学 代码: #include <bits/std ...

  6. cpp extern 关键字用法

    语法说明: extern 可以置于变量或者函数前,以标示变量或者函数的在别的文件中定义,提示编译器遇到此变量和函数后,在其他模块中寻找其定义.此外extern也可用来进行链接指定. 即 extern ...

  7. 利用uiautomator实现Android移动app启动时间的测试

    为了减少因手工测试的反应误差,这里介绍下如何利用Android自带的自动化测试工具uiautomator实现app启动时间的测试. 测试基本思路如下: 1.启动前记录当前的时间戳 2.启动app,直至 ...

  8. js 获取最后一个字符

    方法一: str.charAt(str.length - 1) 方法二: str.subStr(str.length-1,1) 方法三:    var str = "123456" ...

  9. RPC之远程过程调用

    一. 简介 将一个函数运行在远程计算机上并且等待获取那里的结果,这个称作远程过程调用(Remote Procedure Call)或者 RPC. RPC是一个计算机通信协议. 1. 类比: 将计算机服 ...

  10. 【学习笔记】深入理解js原型和闭包系列学习笔记——精华

    深入理解js原型和闭包笔记: 1.“一切皆是对象”,对象是属性的集合. 丨 函数也是对象,但是使用typeof时为什么函数返回function而 丨  不是object呢,js为何要对函数做这样的区分 ...