首頁 >web前端 >css教學 >關於CSS3的animate如何實現「...」loading動畫效果(二)

關於CSS3的animate如何實現「...」loading動畫效果(二)

黄舟
黄舟原創
2017-05-26 13:19:371600瀏覽

box-shadow實現的打點效果

簡介

#box-shadow理論上可以產生任意的圖形效果,當然也就可以實現點點點的loading效果了。

實作原則

html程式碼,首先需要寫如下html程式碼以及class類別名稱:

订单提交中<span class="dotting"></span>

css程式碼

.dotting {
    display: inline-block; min-width: 2px; min-height: 2px;
    box-shadow: 2px 0 currentColor, 6px 0 currentColor, 10px 0 currentColor; /* for IE9+, ..., 3个点 */
    animation: dot 4s infinite step-start both; /* for IE10+, ... */
    *zoom: expression(this.innerHTML = &#39;...&#39;); /*  for IE7. 若无需兼容IE7, 此行删除 */
}
.dotting:before { content: &#39;...&#39;; } /* for IE8. 若无需兼容IE8, 此行以及下一行删除*/
.dotting::before { content: &#39;&#39;; } /* for IE9+ 覆盖 IE8 */
:root .dotting { margin-right: 8px; } /* for IE9+,FF,CH,OP,SF 占据空间*/

@keyframes dot {
    25% { box-shadow: none; }                                  /* 0个点 */
    50% { box-shadow: 2px 0 currentColor; }                    /* 1个点 */
    75% { box-shadow: 2px 0 currentColor, 6px 0 currentColor;  /* 2个点 */ }
}

這裡用到了currentColor這個關鍵字,IE9+瀏覽器支持,其可以讓CSS產生的圖形的顏色跟所處環境的color屬性值一樣,也就是跟文字顏色一樣。

各瀏覽器實現的效果如圖所示:
關於CSS3的animate如何實現「...」loading動畫效果(二)

#不足

#雖然幾乎所有瀏覽器都有模有樣,但是,從效果上講,還是有瑕疵的,IE10+以及FireFox瀏覽器下的點的邊緣有些虛(參見下截圖),雖然CSS代碼並沒有設定盒陰影模糊。這種羽化現象可以讓IE以及FireFox在大數值盒陰影時候效果更接近photoshop的陰影效果;但是,在小尺寸陰影時候,並不是我們想要的。
關於CSS3的animate如何實現「...」loading動畫效果(二)

border + background實作的打點效果

實作原理

html程式碼

订单提交中<span class="dotting"></span>

css程式碼

.dotting {
    display: inline-block; width: 10px; min-height: 2px;
    padding-right: 2px;
    border-left: 2px solid currentColor; border-right: 2px solid currentColor;   
    background-color: currentColor; background-clip: content-box;
    box-sizing: border-box;
    animation: dot 4s infinite step-start both;
    *zoom: expression(this.innerHTML = &#39;...&#39;); /* IE7 */
}
.dotting:before { content: &#39;...&#39;; } /* IE8 */
.dotting::before { content: &#39;&#39;; }
:root .dotting { margin-left: 2px; padding-left: 2px; } /* IE9+ */

@keyframes dot {
    25% { border-color: transparent; background-color: transparent; }          /* 0个点 */
    50% { border-right-color: transparent; background-color: transparent; }    /* 1个点 */
    75% { border-right-color: transparent; }                                   /* 2个点 */
}

#說明:

1.同樣是4秒動畫,每秒鐘顯示1個點;
2.IE7/IE8實作原理跟上面box-shadow方法一致,都是內容生成,如果無需相容IE7/IE8, 可以按照第一個範例CSS程式碼註解說明刪除一些CSS;
3.currentColor關鍵字可以讓圖形字元化,不可或缺;
4.最大功臣是CSS3 background-clip屬性,可以讓IE9+瀏覽器下左右padding沒有背景色,於是形成了等分打點效果。
5.box-sizing是讓現代瀏覽器和IE7/IE8佔據寬度完全一樣的功臣:IE7/IE8實際寬度是width+padding-right為12像素,其他現代瀏覽器為width+margin-left也是12像素;
6.這裡CSS程式碼主要用來展示原理,故沒有顯示-webkit-animation以及@-webkit-keyframes私有前綴,實際目前還是需要的;

#

以上是關於CSS3的animate如何實現「...」loading動畫效果(二)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn