前言:類的使用
<head>
<meta charset="UTF-8">
<title>ssss</title>
<style>
.a{
color: tomato;
}
.b{
font-size:40px;
}
.c{
}
</style>
</head>
<body>
<div class="a b">話多多1</div>
<div class="a c">話多多2</div>
<div class="c b">話多多3</div>
</body>
一.高級選擇器
1.後代選擇器 語法:用空格鏈接類名,逐層精準
<head>
<meta charset="UTF-8">
<title>ssss</title>
<style>
div div p span{
color: darkred;
}
</style>
</head>
<body>
<div class="a b">
話多多1
<div>
<p>
<span>拼多多</span>
</p>
</div>
</div>
<div class="a c">話多多2</div>
<div class="c b">話多多3</div>
</body>
2.子代選擇器 語法:父類元素名>子類元素名>孫類元素名...
<head>
<meta charset="UTF-8">
<title>aaa</title>
<style>
div>div>p>span{
color: #1cb7fd;
}
</style>
</head>
<body>
<div >
<div >
<p >
aaa
<span>
bbb
</span>
ccc
</p>
</div>
</div>
</body>
3.組合選擇器(多個選擇器放到一塊兒共同設置樣式) 語法:選擇器,選擇器,選擇器...
<head>
<meta charset="UTF-8">
<title>aaa</title>
<style>
div>p,p,a{
color: #33bb66;
}
</style>
</head>
<body>
<div >
aaa
<div >
aaa
<span>
bbb
</span>
ccc
</div>
<p>
hhh
</p>
</div>
<p>
很關鍵國際化
</p>
<a href="http://www.baidu.com">百度一下</a>
</body>
4.交集選擇器 語法:元素.類名
<head>
<meta charset="UTF-8">
<title>qqq</title>
<style>
div{
color: #888888;
}
div.aaa{
color: #33bb66;
}
p.ccc{
color: tomato;
}
</style>
</head>
<body>
<div class="aaa">aaa</div>
<div class="bbb">
bbb
<span>ddd</span>
</div>
<p class="ccc">ccc</p>
</body>
5.屬性選擇器 語法:元素[屬性=屬性值]
<head>
<meta charset="UTF-8">
<title>jjj</title>
<style>
a[href="http://www.baidu.com"]{
font-size:30px;
}
a[href="http://www.luffycity.com"],a[href="http://www.192.168.13.12.com"]{
color: #dedede;
}
</style>
</head>
<body>
<a href="http://www.baidu.com">百度一下</a>
<a href="http://www.luffycity.com">百度一下</a>
<a href="http://www.192.168.13.12.com">百度一下</a>
</body>
6.僞類選擇器 (主要針對a標籤) 語法:元素名:LoVe HAte
愛恨準則:LoVe HAte
<head>
<meta charset="UTF-8">
<title>weilei</title>
<style>
#沒有被訪問的a標籤的顏色
a:link{
color: #333333;
}
#訪問事後的a標籤的顏色
a:visited{
color: crimson;
}
#鼠標懸停是時a標籤的顏色
a:hover{
color: tomato;
}
#點擊時a標籤的顏色
a:active{
color: maroon;
}
</style>
</head>
<body>
<a href="#">點我吧</a>
點擊父類,讓子類作某些事情 語法: .father:hover .son
<head>
<meta charset="UTF-8">
<title>weilei</title>
<style>
.son{
display: none;
}
.father:hover .son{
display:block;
}
</style>
</head>
<body>
<div class="father">
點我
<div class="son">
<ol>
<li>購物</li>
<li>註冊</li>
<li>登陸</li>
</ol>
</div>
</div>
</body>
7.僞元素選擇器
<head>
<meta charset="UTF-8">
<title>weiyuansu</title>
<style>
div p:before{
content: 'h#d#f';
}
p:after{
content: '%%%';
}
p:first-letter{
color: red;
font-size: 26px;
}
</style>
</head>
<body>
<div>
<p>alex</p>
</div>
僞元素在佈局中的應用
<head>
<meta charset="UTF-8">
<title>weiyuansu</title>
<style>
.box{
/*display: none;*/隱藏元素,不佔位置
效果是把span變成了塊級標籤,而且不在頁面中佔位置
/*display: block;*/
/*visibility: hidden;*/隱藏元素,佔位置
/*height: 0;*/
}
div,p{
color: tomato;
}
</style>
</head>
<body>
<p>alex</p>
<span class="box">alex</span>
<div>alex</div>
</body>
二.css的繼承性和層疊性
繼承:color、text-xxx、font-xxx、line-xxx的屬性是能夠繼承下來。盒模型的屬性是不能夠繼承下來的
a標籤有特殊狀況,設置a標籤的字體顏色 必定要選中a,不要使用繼承性
<head>
<meta charset="UTF-8">
<title>jicehng</title>
<style>
.box{
color: tomato;
}
.box a{
color: #33bb66;
}
.box p{
color: green;
font-size: 30px;
line-height: 30px;
background-color: red;
text-align: center;
}
</style>
</head>
<body>
<div class="box">
qwe
<a href="#">點擊</a>
<p>
asd
<span>zxc</span>
</p>
</div>
</body>
層疊性:覆蓋,誰的權重大,就顯示誰的樣式
<head>
<meta charset="UTF-8">
<title>cengdie</title>
<style>
/*0 0 1*/
div{
color: #33bb66;
}
/*0 1 0*/
.box{
color: tomato;
}
/*1 0 0*/
#aaa{
color: #1cb7fd;
}
/*css的層疊性:誰的權重大,就會顯示誰的樣式*/
/*權重:數選擇器 id>class>標籤*/
</style>
</head>
<body>
<div class="box" id="aaa">你猜我是什麼顏色</div>
</body>
例子1:
<head>
<meta charset="UTF-8">
<title>shenru</title>
<style>
/*2 2 0*/
#father1 .box2 #father3 .box4{
color: tomato;
}
/*1 2 1*/
#father1 .box2 .box3 p{
color: #1cb7fd;
}
</style>
</head>
<body>
<div class="box1" id="father1">
<ul class="box2" id="father2">
<li class="box3" id="father3">
<p class="box4" id="child">猜猜個人顏色</p>
</li>
</ul>
</div>
</body>
例子2:
<head>
<meta charset="UTF-8">
<title>
</title>
<style>
/*繼承來的屬性 它的權重爲0,跟選中的標籤沒有可比性*/
#father1 #father2 #father3{
color: red;
}
#father1 .box2 .box3 p{
color: green;
}
</style>
</head>
<body>
<div class="box1" id="father1">
<ul class="box2" id="father2">
<li class="box3" id="father3">
<p class="box4" id="child">猜猜個人顏色</p>
</li>
</ul>
</div>
</body>
例子3:
<head>
<meta charset="UTF-8">
<title>zaici</title>
<style>
/*若是都是繼承來的,權重都是0,那就近原則,誰更深刻顯示誰的屬性*/
#father1{
color: #1cb7fd;
}
.box1 #father2{
color: tomato;
}
</style>
</head>
<body>
<div class="box1" id="father1">
<ul class="box2" id="father2">
<li class="box3" id="father3">
<p class="box4" id="child">猜猜個人顏色</p>
</li>
</ul>
</div>
</body>
例子4:
<head>
<meta charset="UTF-8">
<title>zaici</title>
<style>
/*都是繼承來的,都是同樣深,再次比較權重*/
/*1 1 0 */
#father1 #father2{
color: #1cb7fd;
}
/*1 1 0*/
.box1 #father2{
color: tomato;
}
</style>
</head>
<body>
<div class="box1" id="father1">
<ul class="box2" id="father2">
<li class="box3" id="father3">
<p class="box4" id="child">猜猜個人顏色</p>
</li>
</ul>
</div>
</body>
三.盒模型
屬性:
content:內容
width:內容的寬度
height:內容的高度
padding:內邊距 內容到邊框的距離
border:邊框
margin:外邊距 另外一個邊到另外一個邊的距離
盒模型的計算:
總結:若是保證盒模型的大小不變,加padding 就必定要減width或者減height
前提是:在標準文檔流
padding:父子之間調整位置
margin: 兄弟之間調整位置
例子:
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.box{
width: 200px;
height: 200px;
background-color: red;
padding: 50px;
border: 10px solid green;
margin-left: 50px;
}
</style>
</head>
<body>
<div class="box"></div>
</body>
調整盒子內的具體位置:
<head>
<meta charset="UTF-8">
<title>Document</title>
<style>
.box{
width: 180px;
height: 180px;
padding-left: 20px;
padding-top: 20px;
border: 1px solid red;
}
span{
background-color: green;
}
.ttt{
margin-left: 30px;
}
</style>
</head>
<body>
<!-- 202*202 -->
<div class="box">
<span>alex</span>
<span class="ttt">alex</span>
</div>
<div class="box">
<span>alex</span>
</div>
</body>
四.佈局方式 浮動
浮動能實現元素並排
盒子浮動就會脫離標準文檔流,不佔位置了,用float屬性浮動,屬性值能夠有left,right