這次帶給大家純css3程式碼實作多個元素依序顯示,純css3程式碼實作多個元素依序顯示的注意事項有哪些,下面就是實戰案例,一起來看一下。
如上圖所示,在許多的活動宣傳html5中會常常需要用到這樣的一個動畫效果。特別是快到年底了,也許有同學正在為了公司的活動頁面而忙碌,get到這樣一個小技能說不定剛好對你有幫助哦。
在css3中,我們使用animation與keyframes結合,可以為元素添加各種各樣的動畫效果。具體的動畫,在keyframes中定義,在animation中使用。例如可以定義一個從上飛入的動畫效果。
@keyframes topIn { from { transform: translateY(-50px) } to { transform: translateY(0px) } }
並在目標元素中透過animation來使用動畫。
<p></p> .topIn { animation: topIn 1s ease; }
這樣,當元素第一次渲染進入DOM時,就會有一個從上到下的位移動畫效果。當然,這種效果並不是我們想要的。往往我們還在在動畫上加上一個透明度從0到1的漸層。
@keyframes topIn { from { transform: translateY(-50px); opacity: 0; } to { transform: translateY(0px); opacity: 1; } }
我們還希望能夠控制元素的顯示時機該怎麼辦?簡單一點的方法就是在需要動畫效果展示時,才會為目標元素加入一個控制動畫的class樣式。
btn.addEventListener('click', function() { document.querySelector('.target').classList.add('topIn'); }, !1);
但是這樣做有一個問題。我相信實踐過的朋友都已經發現過的。我們期望元素在入場前,是處於看不見的狀態。但是僅僅只是上面的做法,動畫開始前元素是能夠被看見的。那該怎麼辦?
我們可以很簡單的想到,為元素加上 display: none 或 visibility: hidden 。但由於 display: none 之後,元素是不佔位的。因此如果這樣的話,會導致頁面佈局出現混亂。所以我們在開始之前,先為元素新增一個新的class。
.aninode { visibility: hidden; }
並且新增一個新的class讓元素顯示出來。
.animated .aninode { visibility: visible; }
控制動畫效果的class也在css上做一些調整。
.animated .topIn { animation: topIn 1s ease; }
這樣做的好處是,我們只需要在class中加入一個 animated ,就能夠達到我們的效果。 實例demo完整程式碼如下:
<p> </p><p></p> <button>show</button> <button>hide</button> .container { width: 100px; margin: 0 auto; } .aninode { visibility: hidden; } .animated .aninode { visibility: visible; } .target { width: 100px; height: 100px; background: orange; border-radius: 4px; margin: 20px 0; } .animated .topIn { animation: topIn 1s ease; } .animated .leftIn { animation: leftIn 1s ease; } .btn { width: 100px; height: 30px; border: 1px solid #ccc; outline: none; transition: 0.1s; } .btn:active { border: none; background: orange; color: #fff; } @keyframes topIn { from { transform: translateY(-50px); opacity: 0; } to { transform: translateY(0px); opacity: 1; } } @keyframes leftIn { from { transform: translateX(-50px); opacity: 0; } to { transform: translateX(0px); opacity: 1; } } var show = document.querySelector('.show'); var hide = document.querySelector('.hide'); var container = document.querySelector('.container'); show.addEventListener('click', function() { container.classList.add('animated'); }, !1); hide.addEventListener('click', function() { container.classList.remove('animated'); }, !1);
Demo顯示如下:
See the Pen <a>NXKrPg</a> by Ormie (<a>@yangbo5207</a>) on <a>CodePen</a>.
codepen demo 位址
但是這樣離我們想要的效果好像還差一點點。繼續思考。首先想要後面的元素比前一個元素晚一點出現,那麼一定是要控制延遲時間,我們就必須有許多設定延遲時間的class。
.delay200 { animation-delay: 200ms; animation-fill-mode: backwards!important; } .delay400 { animation-delay: 400ms; animation-fill-mode: backwards!important; } .delay600 { animation-delay: 600ms; animation-fill-mode: backwards!important; } .delay800 { animation-delay: 800ms; animation-fill-mode: backwards!important; }
animation-fill-mode: backwards!important; 的目的是為了元素在出現之前,保持透明度為0的狀態。防止當添加 animated 之後元素直接出現了。
加上 !important 是為了防止在新的class中使用animation簡寫時對 animation-fill-mode 的屬性進行覆寫改寫。如果這裡不寫 !important 的話,那麼在 topIn 這樣的動畫class中就不能使用簡寫形式。
這樣之後,我們只需要在css中加入上述程式碼,並對html做一些改動,就能夠實現我們想要的效果了。
See the Pen <a>mpbEEE</a> by Ormie (<a>@yangbo5207</a>) on <a>CodePen</a>.
codepen demo 位址
完整程式碼如下:
<p> </p><p> </p><p>春晓</p> <p>春眠不觉晓</p> <p>处处蚊子咬</p> <p>夜来风雨声</p> <p></p> <button>show</button> <button>hide</button> .container { width: 200px; margin: 0 auto; } .aninode { visibility: hidden; } .animated .aninode { visibility: visible; } .targets { margin: 20px 0; } .targets .item { border: 1px solid #ccc; margin: 10px 0; line-height: 2; padding: 2px 6px; border-radius: 4px; } .animated .topIn { animation: topIn 1s ease; } .animated .leftIn { animation-name: leftIn; animation-duration: 1s; } .btn { width: 100px; height: 30px; border: 1px solid #ccc; outline: none; transition: 0.1s; } .btn:active { border: none; background: orange; color: #fff; } @keyframes topIn { from { transform: translateY(-50px) } to { transform: translateY(0px) } } @keyframes leftIn { from { transform: translateX(-50px); opacity: 0; } to { transform: translateX(0px); opacity: 1; } } .delay200 { animation-delay: 200ms; animation-fill-mode: backwards!important; } .delay400 { animation-delay: 400ms; animation-fill-mode: backwards!important; } .delay600 { animation-delay: 600ms; animation-fill-mode: backwards!important; } .delay800 { animation-delay: 800ms; animation-fill-mode: backwards!important; } var show = document.querySelector('.show'); var hide = document.querySelector('.hide'); var container = document.querySelector('.container'); show.addEventListener('click', function() { container.classList.add('animated'); }, !1); hide.addEventListener('click', function() { container.classList.remove('animated'); }, !1);
我們發現js的邏輯並沒有任何改變。仍然僅僅只是在合適的位置添加/刪除animated。
彩蛋:
在實踐中我們還會遇到一個比較麻煩的事兒。就是延遲class的編寫。我們可能不知道會使用到那些時差,有多少個元素會使用到,如果都用用手寫的話,重複工作確實太過麻煩。因此我們可以使用js動態插入。程式碼如下:
const styleSheet = getSheet(); var delay = 100; while (delay <p style="text-align: left;"><span style="color: #ff0000"></span></p><p>相信看了本文案例你已經掌握了方法,更多精彩請關注php中文網其它相關文章! </p><p>推薦閱讀:</p><p style="text-align: left;"><a href="http://www.php.cn/css-tutorial-389392.html" target="_blank">CSS怪異盒模型和標準盒模型如何使用</a><br></p><p style="text-align: left;">##CSS實現手風琴佈局<a href="http://www.php.cn/css-tutorial-389389.html" target="_blank"> </a><br></p>
以上是純css3程式碼實作多個元素依序顯示的詳細內容。更多資訊請關注PHP中文網其他相關文章!

在這篇文章中,布萊克·莫里(Blackle Mori)向您展示了一些駭客,同時試圖推動同位HTML支持的極限。如果您敢於使用這些,以免您也被標記為CSS罪犯。

具有CSS的自定義光標很棒,但是我們可以將JavaScript提升到一個新的水平。使用JavaScript,我們可以在光標狀態之間過渡,將動態文本放置在光標中,應用複雜的動畫並應用過濾器。

互動CSS動畫和元素相互啟動的元素在2025年似乎更合理。雖然不需要在CSS中實施乒乓球,但CSS的靈活性和力量的增加,可以懷疑Lee&Aver Lee有一天會成為一種

有關利用CSS背景濾波器屬性來樣式用戶界面的提示和技巧。您將學習如何在多個元素之間進行背景過濾器,並將它們與其他CSS圖形效果集成在一起以創建精心設計的設計。

好吧,事實證明,SVG的內置動畫功能從未按計劃進行棄用。當然,CSS和JavaScript具有承載負載的能力,但是很高興知道Smil並沒有像以前那樣死在水中

是的,讓#039;跳上文字包裝:Safari Technology Preview In Pretty Landing!但是請注意,它與在鉻瀏覽器中的工作方式不同。

此CSS-tricks更新了,重點介紹了年鑑,最近的播客出現,新的CSS計數器指南以及增加了幾位新作者,這些新作者貢獻了有價值的內容。

在大多數情況下,人們展示了@Apply的@Apply功能,其中包括Tailwind的單個property實用程序之一(會改變單個CSS聲明)。當以這種方式展示時,@Apply聽起來似乎很有希望。如此明顯


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

VSCode Windows 64位元 下載
微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3 Linux新版
SublimeText3 Linux最新版

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),