亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > CSS > 正文

CSS3 animation steps 函數詳解

2024-07-11 09:00:15
字體:
來源:轉載
供稿:網友

這幾天在看一些 css3 動畫的源碼實現時,發現 css 代碼的 animation 當中有一個比較陌生的單詞 steps ,在源碼中是這么寫的:

animation: thunder 2s steps(1, end) infinite;

查閱相關資料后發現 steps 函數是 animation-timing-function 屬性的一個值,那這個函數相較于其他值比如 ease , linear 的區別在哪里呢。

steps

在查閱相關資料后才發現自己之前對 animation-timing-function 了解不夠充分,實際上 animation-timing-function 的 function 指的是 steps() 和  cubic-bezier( ) 即貝塞爾曲線函數這兩個函數,像 linear , ease 這些值其實是   cubic-bezier() 函數的特殊值, steps() 函數同樣也有兩個特殊值: step-start step-end 。在了解這些前提后,下面來具體分析 steps 函數的作用。

實際上 steps 函數和   cubic-bezier 函數分別對應動畫的兩種形式:跳躍式和連貫式?;仡櫰匠N覀兪窃趺词褂?nbsp; cubic-bezier 函數的:

div {  animation: move 1s linear infinite alternate;}@keyframes move {  0% {    margin-left: 0;  }  30% {    margin-left: 50px;  }  100% {    margin-left: 100px;  }}

我們只需要在 @keyframes 中定義關鍵幀, cubic-bezier 函數會幫助我們在關鍵幀之間補幀使其成為流暢的動畫,但有時候我們不希望動畫連貫的播放,而是跳躍式的播放,那我們就需要借助 steps 函數了。

steps函數接收兩個參數: number 和 position 。 number 是正整數, position 有兩個值: start 和 end 。前面我們提到 steps 的兩個特殊值: step-start 和 step-end ,實際上它們分別代表 steps(1, start) 和 steps(1, end) 。那這兩個參數分別代表什么含義呢?

number: number 表示動畫被分成了多少段,比如上述例子表示 div 從 0px 移動到 100px 的這一整段過程一共被分成 4 段。

position: position 參數可選,默認為 end 。 start 與 end 的含義是什么呢,我的理解是: number 會將整個動畫過程分成多段或者說多個周期, start 表示動畫的狀態會在每個周期的起始點瞬間完成變化,而 end 則表示動畫的狀態會在每個周期的結束點瞬間完成變化。這里附上 W3C 官方文檔上的一張圖片:

 

上圖的坐標系中,x軸代表時間,y軸代表動畫的進度,在這張圖中我們需要注意的是實心圓點,實心圓點表示的是動畫所處的狀態。我們來看第一張圖,它表示的是 steps(1, start) 。根據前面的解釋,整段動畫將會作為一段也就是只有一個周期,而指定了 start 參數使得動畫會在周期的起始點狀態發生改變,所以我們可以看到第一個實心圓點的坐標為 (0,1) 。對于第二張圖片,由于指定了 end ,所以動畫的狀態會在周期的結束點突變,因此對應兩個實心圓點的坐標為 (0,0) 和 (1,1) 。下面的 steps(3, start) 和 steps(3, end) 也是同樣的道理,這里就不具體分析了。

接下來為了更加直觀的感受 steps 函數的作用,舉幾個例子來加深理解:

這里先舉一個連貫動畫來作為參考,部分代碼如下:

div {  width: 100px;  height: 100px;  background-color: red;  animation: move 2s linear;}@keyframes move {  0% {    margin-left: 0;  }  100% {    margin-left: 200px;  }}

效果如下:

 

可以看到紅方塊是經過 2s 勻速運動到終點,然后回到起始位置

接下來是 steps(1, start) 的例子:

div {  width: 100px;  height: 100px;  background-color: red;  animation: move 2s step-start;}

效果如下:

 

可以看到在我點擊刷新的一瞬間方塊就到達了終點,然后經過 2s 后回到起始位置

再來看看 steps(1, end) 的例子:

div {  width: 100px;  height: 100px;  background-color: red;  animation: move 2s step-end;}

效果如下:

 

可以看到當點擊刷新時方塊并沒有運動,這是因為方塊會在 2s 后瞬間移動到 200px 的位置,然后動畫結束,回到起始位置,由于這個過程特別快,肉眼是看不到的,所以看上去就好像方塊沒有運動。如果想要停留在終點只需要給 div 加上 animation-fill-mode: forwards 即可。

我們再來看看分成多段的情況,首先 start 分成多段:

div {  width: 100px;  height: 100px;  background-color: red;  animation: move 4s steps(4, start);}

效果如下:

 

上述例子我們將 4s 動畫分成 4 個周期,方塊會在每個周期起始點也就是 0s ,1s ,2s ,3s 處發生位移,從上述效果圖我們也可以看出,在我點擊刷新瞬間就完成了一次狀態變化,然后在 3s 后達到終點,在終點待了 1s 到動畫結束,回到起始位置。

再來看 end 分成多段的情況:

div {  width: 100px;  height: 100px;  background-color: red;  animation: move 4s steps(4, end);}

效果如下:

 

指定 end 會使動畫狀態在每個周期的結束點發生變化,對應例子就是在 1s ,2s ,3s ,4s 處發生變化。從上述效果圖我們也可以看出方塊在我點擊刷新的 1s 后開始運動,在 4s 方塊移動到終點的瞬間由于動畫結束的原因又移動到起始位置,所以會產生方塊好像沒有移動到終點的錯覺。

總結

以上所述是小編給大家介紹的CSS3 animation – steps 函數詳解,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲丁香久久久| 麻豆国产va免费精品高清在线| 成人www视频在线观看| 久久综合久中文字幕青草| 97精品伊人久久久大香线蕉| 欧美另类99xxxxx| 欧美性69xxxx肥| 国产精品一区二区久久久久| 91日韩在线播放| 亚洲精品国产suv| 日本中文字幕不卡免费| 亚洲级视频在线观看免费1级| 亚洲视频在线观看免费| 91亚洲精品久久久久久久久久久久| 亚洲**2019国产| 国产欧美韩国高清| 亚洲欧美日韩精品久久| 成人福利视频在线观看| 一区二区在线视频播放| 亚洲性猛交xxxxwww| 日韩中文在线中文网在线观看| 欧美三级免费观看| 51精品国产黑色丝袜高跟鞋| 欧美日韩精品中文字幕| 91欧美精品午夜性色福利在线| 亚洲天堂男人天堂女人天堂| 久久视频精品在线| 久久成人精品视频| 中文字幕久热精品视频在线| 亚洲精品一区二区三区婷婷月| 91av视频在线免费观看| 日本老师69xxx| 国产综合在线观看视频| 成人有码在线视频| 日韩av一区二区在线观看| 国产精品久久久久影院日本| 在线免费观看羞羞视频一区二区| 久久久91精品| 欧美在线xxx| 欧美中文在线视频| 色伦专区97中文字幕| 国产精品扒开腿做爽爽爽的视频| 在线精品视频视频中文字幕| 亚洲美女黄色片| 欧美午夜宅男影院在线观看| 成人精品网站在线观看| 国产欧美一区二区三区视频| 国产精品r级在线| 欧美黄色性视频| 亚洲综合色av| 国语自产精品视频在线看一大j8| 国产成人精品视| 最新69国产成人精品视频免费| 色哟哟入口国产精品| 精品久久久久久久久久久久| 久久人人爽人人爽人人片av高清| 国产精品视频永久免费播放| 亚洲四色影视在线观看| 日韩中文第一页| 国产精品高清在线观看| 国产在线一区二区三区| 深夜精品寂寞黄网站在线观看| 97在线视频精品| 成人精品在线视频| 97人洗澡人人免费公开视频碰碰碰| 久久精品视频播放| 原创国产精品91| 日韩经典中文字幕在线观看| 久久精品久久久久久国产 免费| 亚洲天堂av女优| 国产欧美在线看| 亚洲国产日韩欧美在线99| 亚洲国产精品成人av| 亚洲天堂久久av| 国产91对白在线播放| 亚洲综合精品一区二区| 奇米四色中文综合久久| 国产盗摄xxxx视频xxx69| 国产精品678| 韩国美女主播一区| 在线日韩中文字幕| 中文字幕一精品亚洲无线一区| 97婷婷大伊香蕉精品视频| 欧美激情一二三| 亚洲淫片在线视频| 精品久久久久久久久久ntr影视| 亚洲视频综合网| 亚洲国产精品系列| 少妇激情综合网| 欧美激情xxxx性bbbb| 国产精品69av| 欧美老少做受xxxx高潮| 国产精品流白浆视频| 亲爱的老师9免费观看全集电视剧| 久久免费国产视频| 亚洲精品中文字幕有码专区| 国产日韩精品电影| 91中文字幕在线观看| 欧美电影在线免费观看网站| 色偷偷88888欧美精品久久久| 国产一区私人高清影院| 欧美精品aaa| 中文字幕欧美精品在线| 国产精品日韩在线| 欧美一级大片在线免费观看| 欧美美最猛性xxxxxx| 欧美成人激情视频| 欧美裸体xxxxx| 精品国偷自产在线视频99| 国产精品白丝av嫩草影院| 成人免费xxxxx在线观看| 日本最新高清不卡中文字幕| 国产日产亚洲精品| 91国在线精品国内播放| 欧美日韩国产区| 亚洲美女视频网| 日韩a**站在线观看| 欧美性xxxxxxx| 欧美性做爰毛片| 国产亚洲精品美女久久久| 国产精品久久在线观看| 国产精品自产拍在线观看| 成人欧美一区二区三区黑人孕妇| 成人欧美一区二区三区黑人孕妇| 亚洲色图第一页| 欧美激情网友自拍| 久久精品99久久久久久久久| 中文欧美日本在线资源| 欧美日韩免费在线观看| 亚洲精品在线91| 久久九九精品99国产精品| 国产精品一区二区久久久久| 91香蕉国产在线观看| 国产ts人妖一区二区三区| 97欧美精品一区二区三区| 91免费电影网站| 成人妇女淫片aaaa视频| 91亚洲人电影| 中国人与牲禽动交精品| 亚洲免费伊人电影在线观看av| 亚洲天堂av图片| 国产a∨精品一区二区三区不卡| 有码中文亚洲精品| 亚洲激情在线观看视频免费| 精品国产鲁一鲁一区二区张丽| 免费av一区二区| 色狠狠av一区二区三区香蕉蜜桃| 久久这里只有精品视频首页| 亚洲精品v欧美精品v日韩精品| 欧洲亚洲免费视频| 青青久久aⅴ北条麻妃| 性欧美视频videos6一9| 91在线网站视频| 韩国视频理论视频久久| 日韩电影在线观看免费| 中文字幕久久精品| 日韩av在线资源| 国产成人精品综合久久久| 懂色aⅴ精品一区二区三区蜜月| 国产九九精品视频| www.99久久热国产日韩欧美.com| 亚洲成年人在线| 久久久久久久色| 亚洲欧美另类在线观看|