CSS3就是出了不少高大上的功能,3D效果、動畫、多列等等。今天寫篇文章記錄怎麼一下怎麼用CSS3寫一個動畫。
醜話還得說前頭,IE9以及以下版本不支援CSS3動畫(如真要實現可以考慮用js,不過估計效果也不太好)。 chrome和safafi建議加上前綴-webkit-以向前兼容舊版本。
今天簡單的做一個動畫。
首先,先簡單畫出一個div,然後再添上背景圖片。
<body> <div class="demo"> 我是demo </div></body>
.demo{ width: 120px; height: 120px; margin: 100px auto; background: url(img/demo.jpg) no-repeat; }
一個普通的DIV就出來了 如右:
接著我們讓它動起來
先寫一個方法,這個方法描述這個圖片該如何運動
@keyframes run_animation{ from { transform: rotatez(0deg); } to { transform: rotatez(360deg); } }
animation_run就是這個方法的名字。等下需要把名字關聯到相關的元素裡。
from是描述動畫的起始狀態,to是動畫的結束狀態。
所以這個方法就是讓一個元素順時針方向轉動360度,非常簡單。
from to往往無法滿足我們日常開發所需,所以還有這種寫法
@keyframes run_animation{ 0%{<br> transform:rotatex(0deg);<br> } 16%{ transform: rotatey(-90deg); } 33%{ transform: rotatey(-90deg) rotatez(135deg); } 50%{ transform: rotatey(225deg) rotatez(135deg); } 66%{ transform: rotatey(135deg) rotatex(135deg); } 83%{ transform: rotatex(135deg); }<br> 100%{<br> transform: rotatex(0deg);<br> } }
這種描述讓動畫可以有更加豐富酷炫的動作。透過百分比來描述每個階段該元素的動態,0%就是上面說的from,100%就是to。其實這個也很簡單對吧~
動畫就這麼容易的寫好了。接下來我們把動畫關聯到我們的圖片上。
.demo{ width: 120px; height: 120px; margin: 100px auto; animation: run_animation 12s linear infinite; /*关联动画名称,定义动画时长,动画播放速度曲线,播放次数*/ background: url(img/demo.jpg) no-repeat 100%; }
就是這麼簡單一句程式碼,圖片就能按照我們定義的方法動起來了。
要是你現在發現動畫沒有動,那可能是下面的原因之一:
1.動畫名稱與@keyframes定義的名稱不符;
2.沒有定義動畫播放時長,預設是0S,即不符;
2.沒有定義動畫播放時長,預設是0S,即不符;
2.沒有定義動畫播放時長,預設是0S,即不符播放動畫。上述程式碼定義12S;
3.在IE9及以下瀏覽器運行該程式碼,IE9及以下不支援CSS3 animation;
4.動畫方法定義不對,方法定義的每個階段中樣式都是一樣的。像下面這樣
@keyframes run_animation{ 0%{ transform: rotatez(90deg); } 50%{ transform: rotatez(90deg); } 100%{ transform: rotatez(90deg); } }
好了,這時候動畫應該是動起來了。接著說動畫中別的選項:
1.animation-iteration-count: 動畫播放次數,想播放幾次就寫幾。我這裡用了無限次就是infinite
2.animation-timing-function:動畫速度曲線。這個速度曲線有點複雜,涉及到一個貝塞爾函數。不想深入探索貝塞爾就直接用現成的linear、ease、ease-in、ease-out、ease-in-out。要是你懂貝塞爾,可以用cubic-bezier(n,n,n,n),這個比較高大上,我覺得是裝逼界的利器。
3.animation-delay:動畫可以延時播放,參數也是n S。和animation-duration不一樣,animation-duration是動畫播放時間。
上面幾個屬性都可以簡寫到animation中,就像我上面的栗子一樣。
還有逆向播放、暫停這些屬性就不說了,有需要可以去看http://www.w3school.com.cn/css3/css3_animation.asp或是
🎜https://developer.mozilla.org/ en-US/docs/Web/CSS/CSS_Animations/Using_CSS_animation🎜🎜🎜
Goofonts是由開發人員和設計師丈夫簽名的附帶項目,它們都是版式的忠實擁護者。我們一直在標記Google

學習如何構建GraphQL API可能具有挑戰性。但是您可以學習如何在10分鐘內使用GraphQL API!碰巧的是,我得到了完美的

這裡是Yuanchuan的一些合法CSS騙局。有此CSS屬性偏移路徑。曾幾何時,它被稱為Motion-Path,然後被更名。我


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

WebStorm Mac版
好用的JavaScript開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

Dreamweaver Mac版
視覺化網頁開發工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。