基本选择器
1.元素选择器 根据元素名称做选择
代码语言:txt复制<div>hello</div>
<div>hello</div>
<div>hello</div>
<div>hello</div>
<p>hello</p>
div{
background: aqua;
color: black;
}
特例: * 选择所有元素 body html也是元素
代码语言:txt复制*{
background: aqua;
color: black;
}
2.属性选择器 []属性
代码语言:txt复制<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选择器
代码语言:txt复制#e{
background-color: aqua;
}
/*id最好唯一*/
4.class选择器
代码语言:txt复制<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;
}
/*特例,结合选择器*/
代码语言:txt复制div.a{
background-color: aquamarine;
}
#ss.a{
color: red;
}
5.包含选择器 selector1 selector2* 空格只是强调包含关系
代码语言:txt复制<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 强调父子关系
代码语言:txt复制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 同级往下找弟弟
代码语言:txt复制<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 选择器之间是或 的关系,只需要满足一个就可以使用该选择器给的样式
代码语言:txt复制<div>hello</div>
<span>hello</span>
<p>hello</p>
<p>hello</p>
div,
p{
background-color: aqua;
}
div,
span,
p{
color: red;
}
伪元素选择器
1.首字母 只有块级元素(竖着布局的元素)可以使用
代码语言:txt复制div::first-letter{
font-size: 40px;
color: purple;
}
2.首行 只有块级元素(竖着布局的元素)可以使用
代码语言:txt复制<div>
<p>hello</p>
<p>hello</p>
</div>
div::first-line{
font-size: 40px;
color: purple;
}
像一串英文字母aaa会看做一行,浏览器认为中文可以随意换行,英文单词或者连字符可以换行,如果是连续的字母没有意义,不会换行,可以用下面的进行换行
代码语言:txt复制div{
word-break: break-all;
}
/*单词裂开*/
<div>
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa
</div>
3.特效追加 在前面追加
代码语言:txt复制div::before{
content: "hello";
background-color: aqua;
color: purple;
}
<div>
world
</div>
4.在元素后面追加 after
代码语言:txt复制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()
只认数字,如果类型恰好符合,则找到*/
代码语言:txt复制
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()
代码语言:txt复制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鼠标选中状态*/
代码语言:txt复制ul li{
background: red;
}
ul li:hover{
background: blue;
}
/* 原本的原色 */
input{
background: blue;
}
/* 开始输入数据 */
input:focus{
background: red;
}
/* 鼠标悬停 */
input:hover{
background: yellow;
}
代码语言:txt复制<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() 排除 过滤掉某些元素 括号中可以写任何一个选择器*/
代码语言:txt复制 <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;
}