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

首頁 > 開發 > CSS > 正文

css3實現多個元素依次顯示效果

2024-07-11 08:58:50
字體:
來源:轉載
供稿:網友

如上圖所示,在許多的活動宣傳html5中會經常需要用到這樣的一個動畫效果。特別是快到年底了,也許有同學正在為了公司的活動頁面而忙碌,get到這樣一個小技能說不定剛好對你有幫助哦。

在css3中,我們使用animation與keyframes結合,可以給元素添加各種各樣的動畫效果。具體的動畫,在keyframes中定義,在animation中使用。例如可以定義一個從上飛入的動畫效果。

@keyframes topIn {  from { transform: translateY(-50px) }  to { transform: translateY(0px) }}

并在目標元素中通過animation來使用動畫。

<div class="target topIn"></div>.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完整代碼如下:

<div class="container">  <div class="target aninode leftIn"></div>  <button class="btn show">show</button>  <button class="btn hide">hide</button></div>.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 地址

完整代碼如下:

<div class="container">  <div class="targets aninode">      <div class="item leftIn">春曉</div>      <div class="item leftIn delay200">春眠不覺曉</div>      <div class="item leftIn delay400">處處蚊子咬</div>      <div class="item leftIn delay600">夜來風雨聲</div>      <div class="item leftIn delay800"><此處請留下你們的才華></div>  </div>  <button class="btn show">show</button>  <button class="btn hide">hide</button></div>.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 < 10000) {    styleSheet.insertRule(`.animated .delay${delay}{ animation-delay: ${delay}ms; animation-fill-mode: backwards; }`, styleSheet.cssRules.length);    delay += delay < 3000 ? 100 : 1000;}function getSheet() {    var sheets = document.styleSheets;    var len = sheets.length;    for(var i = 0; i <= len; i++) {        var sheet = sheets.item(i);        try {            if (sheet.cssRules) {                return sheet;            }        } catch(e) {}     }    var style = document.createElement('style');    style.type = "text/css";    document.getElementsByTagName('head')[0].appendChild(style);    return style.sheet;}

總結

以上所述是小編給大家介紹的css3實現多個元素依次顯示效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩电影在线观看永久视频免费网站| 国产成人精品日本亚洲专区61| 97婷婷大伊香蕉精品视频| 亚洲女人天堂成人av在线| 久久久免费在线观看| 欧美激情影音先锋| 2024亚洲男人天堂| 国产精品美女久久久久av超清| 国产一区二区三区日韩欧美| 成人h视频在线| 欧美美女18p| 最近2019中文免费高清视频观看www99| 91影院在线免费观看视频| 国产热re99久久6国产精品| 中文字幕在线日韩| 成人久久一区二区| 久久久久国产一区二区三区| 在线电影欧美日韩一区二区私密| 亚洲永久在线观看| 欧洲一区二区视频| 在线精品播放av| 激情成人在线视频| 日韩精品www| 久久久www成人免费精品| 欧美日韩精品在线视频| 26uuu另类亚洲欧美日本一| 色777狠狠综合秋免鲁丝| 欧美成人免费观看| 亚洲午夜精品久久久久久性色| 亚洲欧洲自拍偷拍| 亚洲国产成人精品女人久久久| 国产97在线|日韩| 91系列在线观看| 欧美一区二粉嫩精品国产一线天| 国产亚洲人成a一在线v站| 青青久久av北条麻妃黑人| 亚洲美女激情视频| 国产精品久久久久久久app| 91精品国产91久久久久| 精品国产一区二区三区久久狼黑人| 欧美黑人狂野猛交老妇| 国内外成人免费激情在线视频网站| 91在线直播亚洲| 精品国产一区av| 国产精品日韩在线一区| 人体精品一二三区| 欧美激情在线观看| 欧洲美女7788成人免费视频| 91人人爽人人爽人人精88v| 国外成人在线播放| 久久高清视频免费| 日韩精品在线私人| 美日韩丰满少妇在线观看| 国外成人在线播放| 国产一区视频在线播放| 欧美制服第一页| 欧美区二区三区| 97精品久久久| 亚洲欧美综合图区| 黄网动漫久久久| 色噜噜国产精品视频一区二区| 欧美激情a∨在线视频播放| 亚洲奶大毛多的老太婆| 91在线观看免费高清| 亚洲香蕉成人av网站在线观看| 久久久久久久国产精品| 2019国产精品自在线拍国产不卡| 亚洲成色777777在线观看影院| 456国产精品| 欧美日韩aaaa| 国产丝袜精品第一页| 国产裸体写真av一区二区| 91精品国产自产在线老师啪| 欧美精品久久一区二区| 亚洲自拍偷拍网址| 亚洲精品国产精品久久清纯直播| 欧美性精品220| 亚洲热线99精品视频| 国产精品久久久久99| 98精品国产高清在线xxxx天堂| 日韩三级成人av网| 国产精品99久久久久久www| 色婷婷av一区二区三区在线观看| 亚洲已满18点击进入在线看片| 欧美激情免费视频| 欧美激情精品久久久久久久变态| 久久99精品视频一区97| 91久久久久久国产精品| 久久精品在线视频| 色视频www在线播放国产成人| 日韩欧美在线免费观看| 成人午夜在线观看| 久热国产精品视频| 国产aⅴ夜夜欢一区二区三区| 国产精品美女免费视频| 日韩电影免费在线观看中文字幕| 国产欧美在线看| 欧美超级免费视 在线| 国产精品美女www| 国产美女精品视频免费观看| 国产97在线|日韩| 海角国产乱辈乱精品视频| 日韩av123| 中文字幕精品久久| 国产中文日韩欧美| 高清欧美一区二区三区| 亚洲高清久久久久久| 久久亚洲综合国产精品99麻豆精品福利| 91精品国产91久久久久久不卡| 国产精品极品美女在线观看免费| 欧美激情免费在线| 亚洲最大的免费| 最近2019中文免费高清视频观看www99| 精品人伦一区二区三区蜜桃网站| 亚洲精品自在久久| 欧美限制级电影在线观看| 一区二区国产精品视频| 富二代精品短视频| 日韩中文在线中文网三级| 久久99国产精品久久久久久久久| 亚洲人成电影在线观看天堂色| 亚洲偷熟乱区亚洲香蕉av| 国产精品成人一区二区三区吃奶| 欧美激情精品久久久久久黑人| 亚洲一区免费网站| 久久久免费av| 亚洲天天在线日亚洲洲精| 欧美一区二区视频97| 国产精品va在线播放我和闺蜜| 欧美性高潮床叫视频| 最近2019免费中文字幕视频三| 精品一区二区三区四区在线| 亚洲一二三在线| 亚洲图中文字幕| 日韩欧美亚洲成人| 中文字幕精品久久| 欧美第一淫aaasss性| 国产精品扒开腿做| zzjj国产精品一区二区| 欧美国产日韩一区二区三区| 5566日本婷婷色中文字幕97| 懂色aⅴ精品一区二区三区蜜月| 91九色国产社区在线观看| 2020久久国产精品| 深夜福利日韩在线看| 亚洲国产精品热久久| 精品国产电影一区| 97视频免费看| 日韩av片免费在线观看| 日韩av中文字幕在线| 欧美高清视频在线观看| 国产一区二区三区网站| 亚洲深夜福利视频| 久久久久女教师免费一区| 欧美尺度大的性做爰视频| 国产成人精品一区二区在线| 久久精品亚洲精品| 一区二区在线视频| 成人激情黄色网| 亚洲视频在线观看视频| 国产精品99蜜臀久久不卡二区| 91精品视频免费看| 欧美激情在线狂野欧美精品| 日韩精品极品在线观看播放免费视频|