欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

css3實現(xiàn)多個元素依次顯示效果

  發(fā)布時間:2017-12-12 16:10:34   作者:佚名   我要評論
在css3中,我們使用animation與keyframes結(jié)合,可以給元素添加各種各樣的動畫效果。這篇文章主要介紹了css3實現(xiàn)多個元素依次顯示效果,需要的朋友可以參考下

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

在css3中,我們使用animation與keyframes結(jié)合,可以給元素添加各種各樣的動畫效果。具體的動畫,在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; 
  }
}

我們還希望能夠控制元素的顯示時機應(yīng)該怎么辦?簡單一點的辦法就是在需要動畫效果展示時,才給目標元素添加控制動畫的class樣式。

btn.addEventListener('click', function() {
  document.querySelector('.target').classList.add('topIn');
}, !1);

但是這樣做有一個問題。我相信實踐過的朋友都已經(jīng)發(fā)現(xiàn)過的。我們期望元素在入場之前,是處于看不見的狀態(tài)。但是僅僅只是上面的做法,動畫開始前元素是能夠被看見的。那么應(yīng)該怎么辦?

我們可以很簡單的想到,給元素添加 display: none 或者 visibility: hidden 。但是由于 display: none 之后,元素是不占位的。因此如果這樣的話,會導(dǎo)致頁面布局出現(xiàn)混亂。所以我們在開始之前,給元素添加一個新的class。

.aninode {
  visibility: hidden;
}

并且添加一個新的class讓元素顯示出來。

.animated .aninode {
  visibility: visible;
}

控制動畫效果的class也在css上進行一些調(diào)整。

.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 地址

但是這樣離我們想要的效果好像還差一點點。繼續(xù)思考。首先想要后面的元素比前一個元素晚一點出現(xiàn),那么肯定是要控制延遲時間,我們就必須有許多設(shè)置延遲時間的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; 的目的是為了元素在出現(xiàn)之前,保持透明度為0的狀態(tài)。防止當添加 animated 之后元素直接出現(xiàn)了。

加 !important 是為了防止在新的class中使用animation簡寫時對 animation-fill-mode 的屬性進行覆蓋改寫。如果此處不寫 !important 的話,那么在 topIn 這樣的動畫class中就不能使用簡寫形式。

這樣之后,我們只需要在css中添加上上述代碼,并對html做一些改動,就能夠?qū)崿F(xiàn)我們想要的效果了。

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">夜來風(fēng)雨聲</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);

我們發(fā)現(xiàn)js的邏輯并沒有發(fā)生任何改變。仍然僅僅只是在合適的位置添加/刪除animated。

彩蛋:

在實踐中我們還會遇到一個比較麻煩的事兒。就是延遲class的編寫。我們可能并不知道會使用到那些時差,有多少個元素會使用到,如果都用手來寫的話,重復(fù)工作確實太過麻煩。因此我們可以使用js動態(tài)插入。代碼如下:

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;
}

總結(jié)

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

相關(guān)文章

  • CSS :befor :after 偽元素的巧妙用法

    本篇重點介紹CSS中的:befor、:after創(chuàng)建的偽元素幾種使用場景,如填充文本、作為iconfont、進度線、時間線以及幾何圖形,感興趣的朋友一起看看吧
    2018-02-07
  • 詳解CSS nth-child與nth-of-type的元素查找方式

    這篇文章主要介紹了詳解CSS nth-child與nth-of-type的元素查找方式的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-22
  • css判斷某元素的子元素個數(shù)并分別設(shè)置樣式的方法

    這篇文章主要介紹了css判斷某元素的子元素個數(shù)并分別設(shè)置樣式的方法的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-17
  • CSS 實現(xiàn)元素較寬不能被完全展示時將其隱藏的方法

    最近做項目遇到這樣的需求,需要實現(xiàn)的樣式是固定寬度的容器里一排顯示若干個標簽,數(shù)量不定,每個標簽的長度也不定。下面小編給大家?guī)砹薈SS 實現(xiàn)元素較寬不能被完全展示
    2017-12-29
  • 單元素利用css實現(xiàn)多重邊框效果示例代碼

    邊框操作是每位前端工程師們經(jīng)常會遇到的,下面這篇文章主要給大家介紹了關(guān)于單元素如何利用css實現(xiàn)多重邊框效果的相關(guān)資料,文中通過示例代碼給大家詳細介紹了實現(xiàn)的過程
    2017-09-18
  • css3之UI元素狀態(tài)偽類選擇器實例演示

    這篇文章主要介紹了css3之UI元素狀態(tài)偽類選擇器 ,其中包括hover、active和focus,enabled,disabledread-only與read-write 等等,需要的朋友可以參考下
    2017-08-11
  • 利用CSS3偽元素實現(xiàn)逐漸發(fā)光的方格邊框

    這篇文章主要給大家介紹了利用CSS3偽元素實現(xiàn)逐漸發(fā)光的方格邊框的相關(guān)資料,文中給出了詳細的示例代碼供大家參考學(xué)習(xí),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來
    2017-05-07
  • css 獲取從第n個開始之后的所有元素

    這篇文章主要介紹了css 獲取從第n個開始之后的所有元素 ,需要的朋友可以參考下
    2018-11-21

最新評論