1.选择器:给谁加样式
三种样式如果对于不同的方面,效果叠加,如果是相同的方面,行内样式的优先级最高,外部样式和内部样式的优先级相等,谁在上面先用谁
2.css的语法规则:
selector{
property:value;
property:value;
}
/* 基本选择器*/
/*1.元素选择器 根据元素名称做选择*/
div{
background: red;
color: yellow;
}
/*特例: * 选择所有元素 */
*{
background: red;
color: yellow;
}
/*2.属性选择器 []属性*/
div[id]{
background: red; /*有id属性*/
color: yellow;
}
div[id=a]{
background: red;/*有id属性,并且id属性值等于a*/
color: yellow;
}
div[id$=a]{
background: red;/*有id属性,并且id属性值以a结尾的div元素*/
color: yellow;
}
div[id^=a]{
background: red;/*有id属性,并且id属性值以a开头的div元素*/
color: yellow;
}
div[id*=a]{
background: red;/*有id属性,并且id属性值包含a的div元素*/
color: yellow;
}
div[mm*=a]{
background: red;/*有mm属性,并且id属性值包含a的div元素 属性值可以自己创造*/
color: yellow;
}
/*3.id选择器*/
#ss{
background: red;
color: yellow;
}
/*id最好唯一*/
/*4.class选择器*/
.ss{
background: red;
color: yellow;
}
/*特例,结合选择器*/
p.ss{
background: red;
color: yellow; /*不要用空格,直接拼接*/
}
/*5.包含选择器 selector1 selector2* 空格只时强调包含关系,时候带就行*/
div p{
background: red;
color: yellow; /*在第一个选择器所包含的元素里面,找第二个选择器满足的元素*/
}
/*6.子选择器 selector1>selector2 强调父子关系*/
div>p{
background: red;
color: yellow; /*在第一个选择器所包含的元素里面,找第二个选择器满足的元素*/
}
/*7.兄弟选择器 selector1~selector2 同级往下找弟弟*/
.php~.java{
background: red;
color: yellow;
}
.php~*{
background: red;
color: yellow;
}
/*8.选择器组合 selector1,selector2,selector3 之间是或的关系*/
p,
span,
div{
background: red;
color: yellow;
}
/* 伪元素选择器*/
/*1.首字母 只有块级元素(竖着布局的元素)可以使用*/
div::first-letter{
font-size: 40px;
color: purple;
}
/*2.首行 只有块级元素(竖着布局的元素)可以使用*/
div::first-line{
font-size: 40px;
color: purple;
}
/*像一串英文字母aaa会看做一行,浏览器认为中文可以随意换行,英文单词或者连字符可以换行,如果是连续的字母没有意义,不会换行,可以用下面的进行换行*/
div{
word-break: break-all;
}
/*单词裂开*/
/*3.特效追加 在前面追加*/
div::before{
content: "111";
font-size: 40px;
color: purple;
}
/*4.在元素后面追加 after*/
div::after{
content: "111";
font-size: 40px;
color: purple;
}
/*!!!!需要通过content开辟空间,进行追加*/
/* 伪类选择器*/
/*1.结构性伪类选择器*/
/*括号里 n可以是数字,如果是数字 n从1开始
可以是单词 even偶数个 odd奇数个
可以是表达式 2n+1 3n+2 n从0开始
找第一个 first-child
找最后一个 last-child
倒数 nth-last-child()
正数 nth-child()
只认数字,如果类型恰好符合,则找到*/
ul li:nth-child(2){
font-size: 40px;
color: purple;
}
ul li:nth-child(2){
font-size: 40px;
color: purple;
}
ul li:nth-child(odd){
font-size: 40px;
color: purple;
}
/*找同类型的 nth-of-type 既认数字,也认类型
括号里 n可以是数字,如果是数字 n从1开始
可以是单词 even偶数个 odd奇数个
可以是表达式 2n+1 3n+2 n从0开始
找第一个 first-of-type
找最后一个 last-of-type
倒数 nth-last-of-type()
正数 nth-of-type()*/
ul li:nth-of-type(1){
font-size: 40px;
color: purple;
}
/*2.UI状态伪类选择器*/
/*hover鼠标悬停状态*/
/*focus鼠标焦点状态*/
/*checked鼠标选中状态*/
ul li:hover{
font-size: 40px;
color: purple;
}
/*3.其他伪类选择器*/
/*not() 排除 过滤掉某些元素 括号中可以写任何一个选择器*/
ul li:not(.java){
font-size: 40px;
color: purple;
}
ul li:not(.java):not(.php){
font-size: 40px;
color: purple;
}
/*CSS选择器优先级*/
/*1.选择器写得越长越准确,优先级越高*/
/*2.优先级 id选择器>class选择器>元素选择器*/
/*3.同级别选择器下,CSS按照代码顺序执行 后面代码会把前面的覆盖掉*/
/*4.终极规则:以上规则适用于绝大部分场景,特殊场景不适用请自行调试*/
3.CSS选择器详细介绍
基本选择器
1.元素选择器 根据元素名称做选择
<div>hello</div>
<div>hello</div>
<div>hello</div>
<div>hello</div>
<p>hello</p>
div{
background: aqua;
color: black;
}
特例: * 选择所有元素 body html也是元素
*{
background: aqua;
color: black;
}
2.属性选择器 []属性
<div id="e">hello</div>
<div id="ab">hello</div>
<div id="ba">hello</div>
<div id="daad">hello</div>
<div mm="baab">hello</div>
<p>hello</p>
div[id]{
color: rgb(55, 0, 255);
}
div[id=e]{
background: red;
}
div[id$=a]{
background: greenyellow;
}
div[id^=a]{
background: rgb(249, 49, 219);
}
div[id*=a]{
background: rgb(19, 178, 246);
color: yellow;
}
div[mm*=a]{
background: rgb(166, 28, 212);
color: yellow;
}
3.id选择器
#e{
background-color: aqua;
}
id最好唯一
4.class选择器
<div class="a">hello</div>
<div>hello</div>
<div id="ss" class="a">hello</div>
<div>hello</div>
<p>hello</p>
</body>
.a{
background-color: blueviolet;
}
特例,结合选择器
div.a{
background-color: aquamarine;
}
#ss.a{
color: red;
}
5.包含选择器 selector1 selector2* 空格只是强调包含关系
<div>
<p>
hello
</p>
</div>
<p>hello</p>
<p class="java">hello</p>
<p class="java ">hello</p>
<p class="php">hello</p>
<p class="java">hello</p>
<p class="java">hello</p>
div p{
background-color: aqua;
}
6.子选择器 selector1>selector2 强调父子关系
div>p{
color: red;
}
<div>
<p>
hello
</p>
</div>
<div>
<h1>
<p>
hello
</p>
</h1>
</div>
<p>hello</p>
<p class="java">hello</p>
<p class="java ">hello</p>
<p class="php">hello</p>
<p class="java">hello</p>
<p class="java">hello</p>
7.兄弟选择器 selector1~selector2 同级往下找弟弟
<p>hello</p>
<p class="java">hello</p>
<p class="java ">hello</p>
<p class="php">hello</p>
<p class="java">hello</p>
<p class="nn">hello</p>
.php~.java{
background-color: blueviolet;
}
.php~*{
background-color: chartreuse;
}/*全选*/
8.选择器组合 selector1,selector2,selector3 选择器之间是或 的关系,只需要满足一个就可以使用该选择器给的样式
<div>hello</div>
<span>hello</span>
<p>hello</p>
<p>hello</p>
div,
p{
background-color: aqua;
}
div,
span,
p{
color: red;
}
伪元素选择器
1.首字母 只有块级元素(竖着布局的元素)可以使用
div::first-letter{
font-size: 40px;
color: purple;
}
2.首行 只有块级元素(竖着布局的元素)可以使用
<div>
<p>hello</p>
<p>hello</p>
</div>
div::first-line{
font-size: 40px;
color: purple;
}
像一串英文字母aaa会看做一行,浏览器认为中文可以随意换行,英文单词或者连字符可以换行,如果是连续的字母没有意义,不会换行,可以用下面的进行换行
div{
word-break: break-all;
}
/*单词裂开*/
<div>
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
</div>
3.特效追加 在前面追加
div::before{
content: "hello";
background-color: aqua;
color: purple;
}
<div>
world
</div>
4.在元素后面追加 after
div::after{
content: "hello";
background-color: aqua;
color: purple;
}
!!!需要通过content开辟空间,进行追加
伪类选择器
1.结构性伪类选择器
括号里 n可以是数字,如果是数字 n从1开始,可以是单词 even偶数个 odd奇数个 可以是表达式 2n+1 3n+2 n从0开始
找第一个 first-child
找最后一个 last-child
倒数 nth-last-child()
正数 nth-child()
只认数字,如果类型恰好符合,则找到
ul li:nth-child(1){
color: blue;
}
ul li:nth-child(2){
color: red;
}/*执行1次*/
ul li:nth-child(2n+1){
font-size: 30px;
}
ul li:nth-child(odd){
background-color:aqua ;
}
ul li:first-child{
background-color:pink ;
}
ul li:last-child{
background-color:rgb(126, 197, 245) ;
}/*执行一次*/
ul li:nth-last-child(even){
background-color: blueviolet;
}/*执行一次*/
<ul>
<li>aaa</li>
<p>aaa</p>
<li>aaa</li>
<li>aaa</li>
<li>aaa</li>
<li>aaa</li>
</ul>
找同类型的 nth-of-type 既认数字,也认类型
括号里 n可以是数字,如果是数字 n从1开始
可以是单词 even偶数个 odd奇数个
可以是表达式 2n+1 3n+2 n从0开始
找第一个 first-of-type
找最后一个 last-of-type
倒数 nth-last-of-type()
正数 nth-of-type()
ul li:nth-of-type(1){
color: blue;
}
ul li:nth-of-type(2){
color: red;
}/*执行1次*/
ul li:nth-of-type(3n){
font-size: 30px;
}
ul li:nth-of-type(odd){
background-color:aqua ;
}
ul li:first-of-type{
background-color:pink ;
}
ul li:last-of-type{
background-color:rgb(126, 197, 245) ;
}/*执行一次*/
ul li:nth-last-child(3){
background-color: blueviolet;
}/*执行一次*/
<ul>
<li>aaa</li>
<p>aaa</p>
<li>aaa</li>
<li>aaa</li>
<li>aaa</li>
<li>aaa</li>
</ul>
2.UI状态伪类选择器
hover鼠标悬停状态
focus鼠标焦点状态
checked鼠标选中状态
/* focus(焦段状态) hover(悬停状态) */
/* 鼠标放上去之前 */
ul li{
background: red;
}
ul li:hover{
background: blue;
}
/* 原本的原色 */
input{
background: blue;
}
/* 开始输入数据 */
input:focus{
background: red;
}
/* 鼠标悬停 */
input:hover{
background: yellow;
}
<html>
<head>
<meta charset="utf-8">
<title>FLOAT</title>
<style>
ul li{
background-color: red;
}
ul li:hover{
background-color: blue;
}
input{
background-color: blueviolet;
}
input:focus{
background-color: greenyellow;
}
input:hover{
background-color: yellow;
}
</style>
</head>
<body>
<ul>
<li>aaa</li>
<li>aaa</li>
<li>aaa</li>
<li>aaa</li>
</ul>
<input type="text">
</body>
</html>
悬停状态
聚焦状态
3.其他伪类选择器
not() 排除 过滤掉某些元素 括号中可以写任何一个选择器*/
<ul>
<li>qcby</li>
<li class="java">qcby</li>
<li>qcby</li>
<li class="java">qcby</li>
<li>qcby</li>
<li class="java">qcby</li>
<li>qcby</li>
<li class="php">qcby</li>
</ul>
/* 排除class是.java的 */
li:not(.java){
background: red;
}
li:not(.java):not(.php){
background: red;
}
欢迎大家,点击关注,加评论呦