HTML5簡(jiǎn)明教程(三)使用CSS3

HTML是骨架,CSS是裝飾谨究,CSS使得網(wǎng)頁(yè)豐富多彩恩袱,它也是Web開(kāi)發(fā)不可或缺的一部分。

同HTML5一樣胶哲,CSS3也存在兼容性問(wèn)題畔塔,不同瀏覽器支持情況不同,甚至鸯屿,特定的瀏覽器指定了特定CSS屬性澈吨。

下表是針對(duì)不同瀏覽器需要的特殊前綴:

前綴 瀏覽器
-moz- Firefox
-webkit- Chrome, Safari
-ms- Internet Explorer
-o- Opera

CSS3新特性分為兩大類,一是支持了新的選擇器寄摆,比如偽類:last-child谅辣,:first-child等等;二是頁(yè)面渲染方面的新功能婶恼。

本文只介紹第二類中比較重要的新特性桑阶。

1. Web字體@font-face

CSS3支持自定義字體,只需要在項(xiàng)目中導(dǎo)入字體文件或者文件鏈接url(常用的有.woff勾邦,.svg蚣录,eot等格式),樣式文件中用@font-face定義字體名检痰,字體文件路徑等等包归。之后,可以在font-familiy屬性中使用自定義字體名铅歼。

例如,我們?cè)陧?xiàng)目中使用google font:

// 定義字體
@font-face {
    font-family: 'BadScript';
    font-style: normal;
    font-weight: 400;
    src: local('Bad Script Regular'), local('BadScript-Regular'), 
         url(../font/googlefonts/rL_b2ND61EQmMOJ8CRr1fhsxEYwM7FgeyaSgU71cLG0.woff) format('woff');
}

// 使用字體
.BadScript {
    font-family: 'BadScript', Georgia, "Times New Roman", Times, serif;
}
2. 多欄文本

支持多欄文本有的CSS3屬性有:

  • column-count設(shè)置欄數(shù)
  • column-width設(shè)置每欄的寬度
3. 媒體查詢media

媒體查詢media可以取得設(shè)備關(guān)鍵信息换可,如大小椎椰,分辨率等等,根據(jù)這些信息應(yīng)用不同樣式沾鳄。

(1)定義樣式表外部鏈接時(shí)使用

<head>
  <!-- 屏幕顯示中使用樣式style.css -->
  <link media = "screen" href="style.css" />
  <!-- 打印頁(yè)面中使用樣式print.css -->
  <link media = "print" href="print.css" />
  <!-- 在480像素設(shè)備且是豎屏情況下應(yīng)用phone.css -->
  <link media = "(max-device-width:480px) and (orientation:portrait)" href="phone.css" />
</head>

(2) CSS樣式表中使用

/*窗口寬度介于600像素到700像素直接慨飘,使用該樣式*/
@media  (min-width: 600px) and (max-width: 700px) { ... }

/*窗口寬度小于400像素使用該樣式*/
@media  (min-width: 400px) { ... }
4.透明度 opacity

注意,opacity值是小數(shù)译荞。

使用opacity給元素設(shè)置透明度瓤的,會(huì)將背景顏色,文本顏色和邊框顏色都變透明吞歼。如果只想設(shè)置其中一種類型的透明度圈膏,可以使用函數(shù)ragb(val1, val2, val3, opacity)

5. 圓角 border-radius

支持矩形圓角篙骡,可以給一個(gè)盒子設(shè)置四個(gè)弧度不同的圓角稽坤。

roundBox {
    border-top-left-radius: 150px 30px; /* 圓弧 */
    border-top-right-radius: 150px 60px;
    border-bottom-left-radius: 150px; /* 半圓弧 */
    border-bottom-right-radius: 150px; 
}
border-radius.png
5. 背景盒子

利用background-xxx幾個(gè)屬性丈甸,可以給盒子設(shè)置背景圖片(應(yīng)用多個(gè)圖片,指定圖片是否重復(fù)尿褪,圖片位置等信息)睦擂。

.bgBox {
  /*設(shè)置多張背景圖片*/
  background-image: url("top-left.png"), url("bottom-right.png");
  /*背景圖片不重復(fù)*/
  background-repeat: no-repeat, no-repeat;
  /*定義背景圖片位置*/
  background-position: left top, right bottom;
}
6. 陰影盒子

CSS3定義了兩種陰影:文字陰影和盒子陰影,分別為text-shadowbox-shadow杖玲,陰影默認(rèn)被設(shè)置在盒子外部顿仇。

該屬性值格式為([]內(nèi)的是可選項(xiàng)):水平偏移量+垂直偏移量+陰影模糊程度[+陰影延伸范圍]+陰影顏色[+inset(在元素內(nèi)部創(chuàng)建陰影)]

.box {
  box-shadow: 1px 5px 10px 20px blue inset;
}
.text {
  text-shadow: 1px 3px 5px green;
}
7. 漸變盒子

漸變是多種顏色混合的效果摆马,有三種漸變:

  • 線性漸變:linear-gradient函數(shù)
  • 徑向漸變:radial-gradient函數(shù)

目前臼闻,需要加瀏覽器前綴來(lái)支持漸變效果,而且今膊,不同瀏覽器支持函數(shù)參數(shù)不同:

/*一個(gè)從左到右的漸變效果*/
background-image: -moz-linear-gradient(left, $leftColor, $rightColor);
background-image: -ms-linear-gradient(left, $leftColor, $rightColor);
background-image: -webkit-gradient(linear, left top, right bottom, color-stop(0, $leftColor), color-stop(1, $rightColor));  
8. 過(guò)渡效果 transition

過(guò)渡效果有:顏色變換些阅,移動(dòng)。利用transition可以讓過(guò)渡效果更佳平滑斑唬。

transition屬性值格式為:過(guò)渡樣式+過(guò)渡時(shí)間

/*在盒子上應(yīng)用兩個(gè)過(guò)渡效果市埋,分為針對(duì)背景色和文本顏色*/
.box {
  transition: background 0.5s, color 0.5s;
}
9. 變換 transform

變換包括移動(dòng),縮放恕刘,旋轉(zhuǎn)等等缤谎,比如45度旋轉(zhuǎn)一個(gè)盒子transform: rotate(45deg)。下面是常用值:

  • 旋轉(zhuǎn)
    • 2D旋轉(zhuǎn):rotate(angle)
    • 3D旋轉(zhuǎn):rotate3d(x,y,z,angle)
    • 沿著X軸3D旋轉(zhuǎn):rotateX(angle)
    • 沿著Y軸3D旋轉(zhuǎn):rotateY(angle)
    • 沿著Z軸3D旋轉(zhuǎn):rotateZ(angle)
  • 縮放
    • 2D縮放:scale(x, y)
    • 3D縮放:scale3d(x,y,z)
  • 位移
    • 2D位移:translate(x,y)
    • 3D位移:translate3d(x,y,z)
    • 沿著X軸位移:translateX(x)
    • 沿著Y軸位移:translateY(x)
    • 沿著Z軸位移:translateZ(x)
  • 傾斜旋轉(zhuǎn)
    • 傾斜旋轉(zhuǎn):skew(x-angle,y-angle)
    • 沿X 軸傾斜旋轉(zhuǎn):skewX(angle)
    • 沿Y 軸傾斜旋轉(zhuǎn):skewY(angle)
10. 動(dòng)畫 animation

動(dòng)畫設(shè)置分為兩部分褐着,一是定義動(dòng)畫幀變化坷澡;二是應(yīng)用動(dòng)畫。

定義動(dòng)畫幀變化含蓉,一般用百分?jǐn)?shù)把動(dòng)畫分割為若干關(guān)鍵點(diǎn)频敛,聲明在keyframes關(guān)鍵字下,分別定義每個(gè)節(jié)點(diǎn)的表現(xiàn)形式馅扣。

下面是一個(gè)W3C官網(wǎng)的例子斟赚,該動(dòng)畫有4個(gè)節(jié)點(diǎn)會(huì)發(fā)生左偏移和背景色變化(建議加上瀏覽器前綴)。

@-webkit-keyframes 'wobble' { 
  0% { 
    margin-left: 100px; 
    background: green; 
  } 
  40% {
    margin-left: 150px; 
    background: orange; 
  } 
  60% { 
    margin-left: 75px; 
    background: blue; 
  } 
  100% { 
    margin-left: 100px; 
    background: red; 
  } 
}

然后用animation屬性應(yīng)用動(dòng)畫:

.box {
  /*動(dòng)畫屬性名差油,也就是前面keyframes定義的動(dòng)畫名*/
  animation-name:'wobble';
  /*動(dòng)畫持續(xù)時(shí)間拗军,以s或者ms計(jì)算*/
  animation-duration: 10s;
  /*動(dòng)畫速度曲線*/
  animation-timing-function: ease-in-out;  
  /*動(dòng)畫延遲時(shí)間*/
  animation-delay: 2s; 
  /*循環(huán)次數(shù),infinite為無(wú)限次*/
  animation-iteration-count: 10; 
  /*是否反向播放動(dòng)畫蓄喇,normal:默認(rèn)值发侵,正常播放;alternate:反向播放*/
  animation-direction: alternate;
}

小結(jié)

CSS3新屬性非常多妆偏,上面10個(gè)只是比較常用的和渲染相關(guān)的功能刃鳄,如果需要進(jìn)一步學(xué)習(xí),可以參考W3C或者developer.mozilla楼眷。

下一節(jié):HTML5簡(jiǎn)明教程(四)Web存儲(chǔ)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末铲汪,一起剝皮案震驚了整個(gè)濱河市熊尉,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌掌腰,老刑警劉巖狰住,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異齿梁,居然都是意外死亡催植,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門勺择,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)创南,“玉大人,你說(shuō)我怎么就攤上這事省核「逭蓿” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵气忠,是天一觀的道長(zhǎng)邻储。 經(jīng)常有香客問(wèn)我,道長(zhǎng)旧噪,這世上最難降的妖魔是什么吨娜? 我笑而不...
    開(kāi)封第一講書人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮淘钟,結(jié)果婚禮上宦赠,老公的妹妹穿的比我還像新娘。我一直安慰自己米母,他們只是感情好勾扭,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著铁瞒,像睡著了一般尺借。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上精拟,一...
    開(kāi)封第一講書人閱讀 51,631評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音虱歪,去河邊找鬼蜂绎。 笑死,一個(gè)胖子當(dāng)著我的面吹牛笋鄙,可吹牛的內(nèi)容都是我干的师枣。 我是一名探鬼主播,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼萧落,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼践美!你這毒婦竟也來(lái)了洗贰?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤陨倡,失蹤者是張志新(化名)和其女友劉穎敛滋,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體兴革,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡绎晃,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了杂曲。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片庶艾。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖擎勘,靈堂內(nèi)的尸體忽然破棺而出咱揍,到底是詐尸還是另有隱情,我是刑警寧澤棚饵,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布煤裙,位于F島的核電站,受9級(jí)特大地震影響蟹地,放射性物質(zhì)發(fā)生泄漏积暖。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一怪与、第九天 我趴在偏房一處隱蔽的房頂上張望夺刑。 院中可真熱鬧,春花似錦分别、人聲如沸遍愿。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)沼填。三九已至,卻和暖如春括授,著一層夾襖步出監(jiān)牢的瞬間坞笙,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工荚虚, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留薛夜,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓版述,卻偏偏與公主長(zhǎng)得像梯澜,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子渴析,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 轉(zhuǎn)自:http://www.cnblogs.com/star91/p/5659134.html 1.HTML5新元...
    程芬KELA閱讀 354評(píng)論 0 0
  • HTML5 1.HTML5新元素 HTML5提供了新的元素來(lái)創(chuàng)建更好的頁(yè)面結(jié)構(gòu): 標(biāo)簽描述 定義頁(yè)面獨(dú)立的內(nèi)容區(qū)域...
    L怪丫頭閱讀 2,809評(píng)論 0 4
  • 變形--旋轉(zhuǎn) rotate() 旋轉(zhuǎn)rotate()函數(shù)通過(guò)指定的角度參數(shù)使元素相對(duì)原點(diǎn)進(jìn)行旋轉(zhuǎn)晚伙。它主要在二維空間...
    阿振_sc閱讀 938評(píng)論 1 5
  • 一吮龄、Web時(shí)代的變遷 二、HTML5與HTML4的區(qū)別 1.新增的元素:section咆疗、article漓帚、aside...
    ZyBlog閱讀 534評(píng)論 0 0
  • 選擇器 CSS3中新添加了很多選擇器,解決了很多之前需要用javascript才能解決的布局問(wèn)題民傻∫饶· elemen...
    lovelydong閱讀 483評(píng)論 0 2