久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

CSS3中的Transition屬性講解

CSS3中的Transition屬性講解HTML5中文學(xué)習(xí)網(wǎng),是中國最大的HTML5中文門戶,為廣大HTML5愛好者提供各種HTML5資料,包括HTML5網(wǎng)站、HTML5資訊、HTML5應(yīng)用、HTML5游戲、HTML5教程、HTML5視頻、HTML5論壇

 

W3C標準中對CSS3transition這是樣描述的:“CSS的transition允許CSS的屬性值在一定的時間區(qū)間內(nèi)平滑地過渡。這種效果可以在鼠標單擊、獲得焦點、被點擊或?qū)υ厝魏胃淖冎杏|發(fā),并圓滑地以動畫效果改變CSS的屬性值。”

下面我們從最簡單的語法和屬性值開始一步一步來學(xué)習(xí)transition的具體使用:

語法:

 

1
2
3
transition : [<'transition-property'> || <'transition-duration'> ||
<'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> ||
<'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]*

 

transition主要包含四個屬性值:執(zhí)行變換的屬性:transition-property;變換延續(xù)的時間:transition- duration;在延續(xù)時間段,變換的速率變化transition-timing-function;變換延遲時間transition- delay。下面分別來看這四個屬性值:

一、transition-property:

語法:

 

1
transition-property : none | all | [ <IDENT> ] [ ',' <IDENT> ]*

 

transition-property是用來指定當元素其中一個屬性改變時執(zhí)行transition效果,其主要有以下幾個值:none(沒有屬 性改 變);all(所有屬性改變)這個也是其默認值;indent(元素屬性名);當其值為none時,transition馬上停止執(zhí)行,當指定為all 時,則元素產(chǎn)生任何屬性值變化時都將執(zhí)行transition效果,ident是可以指定元素的某一個屬性值。其對應(yīng)的類型如下:

1、color: 通過紅、綠、藍和透明度組件變換(每個數(shù)值單獨處理),如:background-color,border-color,color,outline-color等CSS屬性;

2、length:真實的數(shù)字,如:word-spacing,width,vertical- align,top,right,bottom,left,padding,outline-width,margin,min-width,min- height,max-width,max-height,line-height,height,border-width,border- spacing,background-position等屬性;

3、percentage:真實的數(shù)字,如:word-spacing,width,vertical- align,top,right,bottom,left,min-width,min- height,max-width,max-height,line-height,height,background-position等屬性;

4、integer離散步驟(整個數(shù)字),在真實的數(shù)字空間,以及使用floor()轉(zhuǎn)換為整數(shù)時發(fā)生,如:outline-offset,z-index等屬性;

5、number真實的(浮點型)數(shù)值,如:zoom,opacity,font-weight等屬性;

6、transform list:詳情請參閱:《CSS3 Transform》。

7、rectangle:通過x、 y、 width和height(轉(zhuǎn)為數(shù)值)變換,如:crop;

8、visibility:離散步驟,在0到1數(shù)字范圍之內(nèi),0表示“隱藏”,1表示完全“顯示”,如:visibility;

9、shadow:作用于color、x、y、和blur(模糊)屬性,如:text-shadow;

10、gradient:通過每次停止時的位置和顏色進行變化。它們必須有相同的類型(放射狀的或是線性的)和相同的停止數(shù)值以便執(zhí)行動畫,如:background-image;

11、paint server (SVG):只支持下面的情況:從gradient到gradient以及color到color,然后工作與上面類似;

12、space-separated list of above:如果列表有相同的項目數(shù)值,則列表每一項按照上面的規(guī)則進行變化,否則無變化;

13、a shorthand property:如果縮寫的所有部分都可以實現(xiàn)動畫,則會像所有單個屬性變化一樣變化。

具體什么CSS屬性可以實現(xiàn)transition效果,在W3C官網(wǎng)中列出了所有可以實現(xiàn)transition效果的CSS屬性值以及值的類型,大家可以點這里了解詳情。這里需要提醒一點是,并不是什么屬性改變都為觸發(fā)transition動作效果,比如頁面的自適應(yīng)寬度,當瀏覽器改變寬度時,并不會觸發(fā)transition的效果。但上述表格所示的屬性類型改變都會觸發(fā)一個transition動作效果。

二、transition-duration:

語法:

 

1
transition-duration : <time> [, <time>]*

transition-duration是用來指定元素 轉(zhuǎn)換過程的持續(xù)時間,取值:<time>為數(shù)值,單位為s(秒),可以作用于所有元素,包括:before和:after偽元素。其默認值是0,也就是變換時是即時的。

三、transition-timing-function:

語法:

 

1
2
3
transition-timing-function : ease | linear | ease-in | ease-out | ease-in-out |
cubic-bezier(<number>, <number>, <number>, <number>) [, ease | linear | ease-in |
ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>)]*

 

取值:

transition-timing-function的值允許你根據(jù)時間的推進去改變屬性值的變換速率,transition-timing-function有6個可能值:

1、ease:(逐漸變慢)默認值,ease函數(shù)等同于貝塞爾曲線(0.25, 0.1, 0.25, 1.0);

2、linear:(勻速),linear 函數(shù)等同于貝塞爾曲線(0.0, 0.0, 1.0, 1.0);

3、ease-in:(加速),ease-in 函數(shù)等同于貝塞爾曲線(0.42, 0, 1.0, 1.0);

4、ease-out:(減速),ease-out 函數(shù)等同于貝塞爾曲線(0, 0, 0.58, 1.0);

5、ease-in-out:(加速然后減速),ease-in-out 函數(shù)等同于貝塞爾曲線(0.42, 0, 0.58, 1.0);

6、cubic-bezier:(該值允許你去自定義一個時間曲線), 特定的cubic-bezier曲線。 (x1, y1, x2, y2)四個值特定于曲線上點P1和點P2。所有值需在[0, 1]區(qū)域內(nèi),否則無效。

其是cubic-bezier為通過貝賽爾曲線來計算“轉(zhuǎn)換”過程中的屬性值,如下曲線所示,通過改變P1(x1, y1)和P2(x2, y2)的坐標可以改變整個過程的Output Percentage。初始默認值為default。

 

其他幾個屬性的示意圖:

 

四、transition-delay:

語法:

 

1
transition-duration : <time> [, <time>]*transition-delay : <time> [, <time>]*

 

transition-delay是用來指定一個動畫開始執(zhí)行的時間,也就是說當改變元素屬性值后多長時間開始執(zhí)行transition效果,取 值:<time>為數(shù)值,單位為s(秒),它的使用和transition-duration極其相似,也可以作用于所有元素,包 括:before和:after偽元素。 默認大小是”0″,也就是變換立即執(zhí)行,沒有延遲。

有時我們不只改變一個CSS效果的屬性,而是想改變兩個或者多個CSS屬性的transition效果,那么我們只要把幾個transition的 聲明串 在一起,用逗號(“,”)隔開,然后各自可以有各自不同的延續(xù)時間和其時間的速率變換方式。但需要值得注意的一點:transition-delay與 transition-duration的值都是時間,所以要區(qū)分它們在連寫中的位置,一般瀏覽器會根據(jù)先后順序決定,第一個可以解析為時間的怭值為 transition-duration第二個為transition-delay。如:

 

1
2
3
4
5
6
a {
-moz-transition: background 0.5s ease-in,color 0.3s ease-out;
-webkit-transition: background 0.5s ease-in,color 0.3s ease-out;
-o-transition: background 0.5s ease-in,color 0.3s ease-out;
transition: background 0.5s ease-in,color 0.3s ease-out; }
}

如果你想給元素執(zhí)行所有transition效果的屬性,那么我們還可以利用all屬性值來操作,此時他們共享同樣的延續(xù)時間以及速率變換方式,如:

 

 

1
2
3
4
5
6
a {
-moz-transition: all 0.5s ease-in;
-webkit-transition: all 0.5s ease-in;
-o-transition: all 0.5s ease-in;
transition: all 0.5s ease-in;
}

綜合上述我們可以給transition一個速記法:transition: <property> <duration> <animation type> <delay>如下圖所示:

 

 

相對應(yīng)的一個示例代碼:

 

1
2
3
4
5
6
p {
-webkit-transition: all .5s ease-in-out 1s;
-o-transition: all .5s ease-in-out 1s;
-moz-transition: all .5s ease-in-out 1s;
transition: all .5s ease-in-out 1s;
}

 

【網(wǎng)站聲明】本站除付費源碼經(jīng)過測試外,其他素材未做測試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請勿用于商業(yè)用途。如損害你的權(quán)益請聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

主站蜘蛛池模板: 精品影院 | 成人av资源在线 | 日韩中文字幕在线视频观看 | 在线一区视频 | 久久国内精品 | 爱高潮www亚洲精品 中文字幕免费视频 | 精品久久久久久 | 国产精品我不卡 | 久久国产婷婷国产香蕉 | 国产激情视频网站 | 欧美成人专区 | 性生生活大片免费看视频 | 亚洲va欧美va天堂v国产综合 | 天天操夜夜拍 | 久久婷婷国产麻豆91 | 精品美女视频在线观看免费软件 | 天天看天天操 | 日韩视频在线一区二区 | 国产精品99久久久久久人 | 中文字幕蜜臀 | 亚洲电影一区二区三区 | 99久久久久国产精品免费 | 国产精品国产 | 黄网免费 | 黄色网址av | 国产91在线播放精品91 | 中文字幕精品一区二区三区精品 | 亚洲国产乱码 | 一区二区三区回区在观看免费视频 | 国产日韩欧美一区二区 | 在线小视频 | 波多野结衣在线观看一区二区三区 | 亚洲成人免费观看 | 日韩中文一区二区 | 粉嫩国产精品一区二区在线观看 | 麻豆毛片| 亚洲bt 欧美bt 日本bt | 日韩成人专区 | 中文字幕高清一区 | 国产一区视频在线 | 亚洲欧美日韩精品久久亚洲区 |