1、介紹css
CSS(Cascading Style Sheet,層疊樣式表)定義如何顯示HTML元素。html
當瀏覽器讀到一個樣式表,它就會按照這個樣式表來對文檔進行格式化(渲染)。git
2、語法github
每一個CSS樣式由兩個組成部分:選擇器和聲明。聲明又包括屬性和屬性值。每一個聲明以後用分號結束瀏覽器
3、CSS的幾種引入方式
ide
一、行內樣式佈局
行內式是在標記的style屬性中設定CSS樣式。性能
<p style="color: red">Hello world.</p> /*註釋:不推薦大量使用*/字體
二、內部樣式網站
嵌入式是將CSS樣式集中寫在網頁的<head></head>標籤對的<style></style>標籤對中。
<head> <meta charset="UTF-8"> <title>Title</title> <style> /*樣式標籤*/ p{ background-color: #2b99ff; } </style> </head>
三、外部樣式
外部樣式就是將css寫在一個單獨的文件中,而後在頁面進行引入便可。推薦使用此方式。
<link href="mystyle.css" rel="stylesheet" type="text/css"/>
4、CSS選擇器
一、基本選擇器
(1)元素選擇器 p {color: "red";} (2)ID選擇器(前面加井號) #i1 { background-color: red; } (3)類選擇器 .c1 { font-size: 14px; } p.c1 { color: red; } (4)通用選擇器 * { color: white; }
二、組合選擇器
(1)後代選擇器 li a { /*li內部的a標籤設置字體顏色*/ color: green; } (2)兒子選擇器 div>p { /*選擇全部父級是 <div> 元素的 <p> 元素*/ font-family: "Arial Black", arial-black, cursive; } (3)毗鄰選擇器 div+p { /*選擇全部緊接着<div>元素以後的兄弟<p>元素*/ margin: 5px; } (4)弟弟選擇器 #i1~p { /*i1後面全部的兄弟p標籤*/ border: 2px solid royalblue; }
三、屬性選擇器
p[title] { /*用於選取帶有指定屬性的元素。*/ color: red; } p[title="213"] { /*用於選取帶有指定屬性和值的元素。*/ color: green; }
四、分組和嵌套
(1)分組 當多個元素的樣式相同的時候,咱們沒有必要重複地爲每一個元素都設置樣式,咱們能夠經過在多個選擇器之間使用逗號分隔的分組選擇器來統一設置元素樣式。 div, p { color: red; } (2)嵌套 多種選擇器能夠混合起來使用 .c1 p { /*.c1類內部全部p標籤設置字體顏色爲紅色*/ color: red; } span.p1{ /*找class爲d1的span標籤設置顏色*/ color: green; }
五、僞類選擇器
a:link { /* 未訪問的連接 */ color: #FF0000 } a:visited { /* 已訪問的連接 */ color: #00FF00 } a:hover { /* 鼠標移動到連接上 */ color: #FF00FF } a:active { /* 選定的連接 */ color: #0000FF } input:focus { /*input輸入框獲取焦點時樣式*/ outline: none; background-color: #eee;
六、僞元素選擇器
經常使用的給首字母設置特殊樣式:
(1)first-letter p:first-letter { font-size: 48px; color: red; } (2)before p:before { /*在每一個<p>元素以前插入內容*/ content:"*"; color:red; } (3)after p:after { /*在每一個<p>元素以後插入內容*/ content:"[?]"; color:blue; } before和after多用於清除浮動。
七、選擇器的優先級
繼承是CSS的一個主要特徵,它是依賴於祖先-後代的關係的。繼承是一種機制,它容許樣式不只能夠應用於某個特定的元素,還能夠應用於它的後代。
然而CSS繼承性的權重是很是低的,是比普通元素的權重還要低的。咱們只要給對應的標籤設置字體顏色就可覆蓋掉它繼承的樣式。
此外,繼承是CSS重要的一部分,咱們甚至不用去考慮它爲何可以這樣,但CSS繼承也是有限制的。有一些屬性不能被繼承,如:border, margin, padding, background等。
除此以外還能夠經過添加 !import方式來強制讓樣式生效,但並不推薦使用。由於若是過多的使用!import會使樣式文件混亂不易維護。
5、CSS屬性相關
一、字體屬性
(1)文字字體
font - family能夠把多個字體名稱做爲一個「回退」系統來保存。若是瀏覽器不支持第一個字體,則會嘗試下一個。瀏覽器會使用它可識別的第一個值。
body
{
font - family: "Microsoft Yahei", "微軟雅黑", "Arial", sans - serif
}
(2)字體大小
p {font - size: 14px;}
若是設置成inherit表示繼承父元素的字體大小值。
(3)font-weight(字體的粗細)
normal 默認值,標準粗細
bold 粗體
bolder 更粗
lighter 更細
100~900 設置具體粗細,400等同於normal,而700等同於bold
inherit 繼承父元素字體的粗細值
(4)文本顏色
顏色屬性被用來設置文字的顏色。是經過CSS最常常的指定:
十六進制值 - 如: #FF0000
一個RGB值 - 如: RGB(255,0,0)
顏色的名稱 - 如: red
還有rgba(255,0,0,0.3),第四個值爲alpha, 指定了色彩的透明度/不透明度,它的範圍爲0.0到1.0之間。
二、文字屬性
(1)文字對齊
text-align 屬性規定元素中的文本的水平對齊方式。
left 左邊對齊 默認值
right 右對齊
center 居中對齊
justify 兩端對齊
(2)文字裝飾
text-decoration 屬性用來給文字添加特殊效果。
none 默認。定義標準的文本。
underline 定義文本下的一條線。
overline 定義文本上的一條線。
line-through 定義穿過文本下的一條線。
inherit 繼承父元素的text-decoration屬性的值。
經常使用的爲去掉a標籤默認的自劃線:
a {
text-decoration: none;
}
(3)首行縮進
將段落的第一行縮進 32像素:
p {
text-indent: 32px;
}
三、背景屬性
background-color: red; /*背景顏色*/ background-image: url('1.jpg'); /*背景圖片*/
背景重複
repeat(默認):背景圖片平鋪排滿整個網頁
repeat-x:背景圖片只在水平方向上平鋪
repeat-y:背景圖片只在垂直方向上平鋪
no-repeat:背景圖片不平鋪
background-repeat: no-repeat; background-position: right top(20px 20px); /*背景位置*/
使用背景圖片的一個常見案例就是不少網站會把不少小圖標放在一張圖片上,而後根據位置去顯示圖片。減小頻繁的圖片請求。
鼠標滾動背景不動的示例: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>滾動背景圖示例</title> <style> * { margin: 0; } .box { width: 100%; height: 500px; background: url("https://www.luffycity.com/static/img/width-bank.1c9d1b0.png") no-repeat center center; background-attachment: fixed; } .d1 { height: 500px; background-color: tomato; } .d2 { height: 500px; background-color: steelblue; } .d3 { height: 500px; background-color: mediumorchid; } </style> </head> <body> <div></div> <div></div> <div></div> <div></div> </body> </html>
四、邊框
(1)邊框屬性
border-width border-style border-color #i1 { border-width: 2px; border-style: solid; border-color: red; }
(2)一般使用簡寫方式:
#i1 {
border: 2px solid red;
}
(3)邊框樣式
none 無邊框。
dotted 點狀虛線邊框。
dashed 矩形虛線邊框。
solid 實線邊框。
除了能夠統一設置邊框外還能夠單獨爲某一個邊框設置樣式,以下所示:
#i1 { border-top-style:dotted; border-top-color: red; border-right-style:solid; border-bottom-style:dotted; border-left-style:none; }
(4)border-radius(圓角邊框)
用這個屬性能實現圓角邊框的效果。
將border-radius設置爲長或高的一半便可獲得一個圓形。
五、display屬性
用於控制HTML元素的顯示效果。
display:"none" HTML文檔中元素存在,可是在瀏覽器中不顯示。通常用於配合JavaScript代碼使用。
display:"block" 默認佔滿整個頁面寬度,若是設置了指定寬度,則會用margin填充剩下的部分。
display:"inline" 按行內元素顯示,此時再設置元素的width、height、margin - top、margin - bottom和float屬性都不會有什麼影響。
display:"inline-block" 使元素同時具備行內元素和塊級元素的特色。
display:"none"與visibility:hidden的區別:
visibility:hidden: 能夠隱藏某個元素,但隱藏的元素仍需佔用與未隱藏以前同樣的空間。也就是說,該元素雖然被隱藏了,但仍然會影響佈局。
display:none: 能夠隱藏某個元素,且隱藏的元素不會佔用任何空間。也就是說,該元素不但被隱藏了,並且該元素本來佔用的空間也會從頁面佈局中消失。
六、 CSS盒子模型
margin: 用於控制元素與元素之間的距離;margin的最基本用途就是控制元素周圍空間的間隔,從視覺角度上達到相互隔開的目的。
padding: 用於控制內容與邊框之間的距離;
Border(邊框): 圍繞在內邊距和內容外的邊框。
Content(內容): 盒子的內容,顯示文本和圖像。
(1)margin外邊距
.margin-test { margin-top:5px; margin-right:10px; margin-bottom:15px; margin-left:20px; } 推薦使用簡寫: .margin-test { margin: 5px 10px 15px 20px; } 順序:上右下左 常見居中: .mycenter { margin: 0 auto; }
(2)padding內填充
.padding-test { padding-top: 5px; padding-right: 10px; padding-bottom: 15px; padding-left: 20px; } 推薦使用簡寫: .padding-test { padding: 5px 10px 15px 20px; } 順序:上右下左
補充padding的經常使用簡寫方式:
# 提供一個,用於四邊;
# 提供兩個,第一個用於上-下,第二個用於左-右;
# 若是提供三個,第一個用於上,第二個用於左-右,第三個用於下;
# 提供四個參數值,將按上-右-下-左的順序做用於四邊;
七、float
在 CSS 中,任何元素均可以浮動。
浮動元素會生成一個塊級框,而不論它自己是何種元素。
關於浮動的兩個特色:
# 浮動的框能夠向左或向右移動,直到它的外邊緣碰到包含框或另外一個浮動框的邊框爲止。
# 因爲浮動框不在文檔的普通流中,因此文檔的普通流中的塊框表現得就像浮動框不存在同樣。
三種取值:
left:向左浮動
right:向右浮動
none:默認值,不浮動
八、clear
clear屬性規定元素的哪一側不容許其餘浮動元素。
left 在左側不容許浮動元素。
right 在右側不容許浮動元素。
both 在左右兩側均不容許浮動元素。
none 默認值。容許浮動元素出如今兩側。
inherit 規定應該從父元素繼承 clear 屬性的值。
注意:clear屬性只會對自身起做用,而不會影響其餘元素。
九、overflow溢出屬性
visible 默認值。內容不會被修剪,會呈如今元素框以外。
hidden 內容會被修剪,而且其他內容是不可見的。
scroll 內容會被修剪,可是瀏覽器會顯示滾動條以便查看其他的內容。
auto 若是內容被修剪,則瀏覽器會顯示滾動條以便查看其他的內容。
inherit 規定應該從父元素繼承 overflow 屬性的值。
overflow(水平和垂直均設置)
overflow-x(設置水平方向)
overflow-y(設置垂直方向)
十、定位(position)
(1)static
static 默認值,無定位,不能看成絕對定位的參照物,而且設置標籤對象的left、top等值是不起做用的的。
(2)relative(相對定位)
相對定位是相對於該元素在文檔流中的原始位置,即以本身原始位置爲參照物。有趣的是,即便設定了元素的相對定位以及偏移值,元素還佔有着原來的位置,即佔據文檔流空間。對象遵循正常文檔流,但將依據top,right,bottom,left等屬性在正常文檔流中偏移位置。而其層疊經過z-index屬性定義。
注意:position:relative的一個主要用法:方便絕對定位元素找到參照物。
(3)absolute(絕對定位)
定義:設置爲絕對定位的元素框從文檔流徹底刪除,並相對於最近的已定位祖先元素定位,若是元素沒有已定位的祖先元素,那麼它的位置相對於最初的包含塊(即body元素)。元素原先在正常文檔流中所佔的空間會關閉,就好像該元素原來不存在同樣。元素定位後生成一個塊級框,而不論原來它在正常流中生成何種類型的框。
重點:若是父級設置了position屬性,例如position:relative;,那麼子元素就會以父級的左上角爲原始點進行定位。這樣能很好的解決自適應網站的標籤偏離問題,即父級爲自適應的,那我子元素就設置position:absolute;父元素設置position:relative;,而後Top、Right、Bottom、Left用百分比寬度表示。
另外,對象脫離正常文檔流,使用top,right,bottom,left等屬性進行絕對定位。而其層疊經過z-index屬性定義。
(4)fixed(固定)
fixed:對象脫離正常文檔流,使用top,right,bottom,left等屬性以窗口爲參考點進行定位,當出現滾動條時,對象不會隨着滾動。而其層疊經過z-index屬性 定義。 注意點: 一個元素若設置了 position:absolute | fixed; 則該元素就不能設置float。這 是一個常識性的知識點,由於這是兩個不一樣的流,一個是浮動流,另外一個是「定位流」。可是 relative 卻能夠。由於它本來所佔的空間仍然佔據文檔流。
在理論上,被設置爲fixed的元素會被定位於瀏覽器窗口的一個指定座標,不論窗口是否滾動,它都會固定在這個位置。
返回頂部按鈕示例: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>返回頂部示例</title> <style> * { margin: 0; } .d1 { height: 1000px; background-color: #eeee; } .scrollTop { background-color: darkgrey; padding: 10px; text-align: center; position: fixed; right: 10px; bottom: 20px; } </style> </head> <body> <div>111</div> <div>返回頂部</div> </body> </html>
6、示例
一、頂部導航菜單
<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>li標籤的float示例</title> <style> /*清除瀏覽器默認外邊距和內填充*/ * { margin: 0; padding: 0; } a { text-decoration: none; /*去除a標籤默認的下劃線*/ } .nav { background-color: black; height: 40px; width: 100%; position: fixed; top: 0; } ul { list-style-type: none; /*刪除列表默認的圓點樣式*/ margin: 0; /*刪除列表默認的外邊距*/ padding: 0; /*刪除列表默認的內填充*/ } /*li元素向左浮動*/ li { float: left; } li > a { display: block; /*讓連接顯示爲塊級標籤*/ padding: 0 15px; /*設置左右各15像素的填充*/ color: #b0b0b0; /*設置字體顏色*/ line-height: 40px; /*設置行高*/ } /*鼠標移上去顏色變白*/ li > a:hover { color: #fff; } /*清除浮動 解決父級塌陷問題*/ .clearfix:after { content: ""; display: block; clear: both; } </style> </head> <body> <!-- 頂部導航欄 開始 --> <div class="nav"> <ul class="clearfix"> <li><a href="">玉米商城</a></li> <li><a href="">MIUI</a></li> <li><a href="">ioT</a></li> <li><a href="">雲服務</a></li> <li><a href="">水滴</a></li> <li><a href="">金融</a></li> <li><a href="">優品</a></li> </ul> </div> <!-- 頂部導航欄 結束 --> </body> </html>
二、圓形頭像
<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <meta http-equiv="x-ua-compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>圓形的頭像示例</title> <style> * { margin: 0; padding: 0; background-color: #eeeeee; } .header-img { width: 150px; height: 150px; border: 3px solid white; border-radius: 100%; overflow: hidden; } .header-img>img { max-width: 100%; } </style> </head> <body> <div class="header-img"> <img src="https://q1mi.github.io/Blog/asset/img/head_img.jpg" alt=""> </div> </body> </html>