本篇內(nèi)容主要講解“如何使用CSS實(shí)現(xiàn)打點(diǎn)Loading效果”,感興趣的朋友不妨來看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“如何使用CSS實(shí)現(xiàn)打點(diǎn)Loading效果”吧!
網(wǎng)站建設(shè)公司,為您提供網(wǎng)站建設(shè),網(wǎng)站制作,網(wǎng)頁設(shè)計(jì)及定制網(wǎng)站建設(shè)服務(wù),專注于企業(yè)網(wǎng)站建設(shè),高端網(wǎng)頁制作,對(duì)發(fā)電機(jī)租賃等多個(gè)行業(yè)擁有豐富的網(wǎng)站建設(shè)經(jīng)驗(yàn)的網(wǎng)站建設(shè)公司。專業(yè)網(wǎng)站設(shè)計(jì),網(wǎng)站優(yōu)化推廣哪家好,專業(yè)成都網(wǎng)站推廣優(yōu)化,H5建站,響應(yīng)式網(wǎng)站。
基于box-shadow實(shí)現(xiàn)的打點(diǎn)效果
理論上,box-shadow可以實(shí)現(xiàn)任意的圖形效果,自然我們可以利用box-shadow生成我們的點(diǎn)效果,然后通過animation控制不同時(shí)間點(diǎn)點(diǎn)的數(shù)目就可以實(shí)現(xiàn)點(diǎn)點(diǎn)點(diǎn)... loading效果了~
您可以狠狠地點(diǎn)擊這里:CSS3 animation box-shadow漸進(jìn)實(shí)現(xiàn)打點(diǎn)動(dòng)畫demo
1. 漸進(jìn)兼容
支持CSS3 animation動(dòng)畫的瀏覽器顯示的就是打點(diǎn)動(dòng)畫效果;對(duì)于不支持的瀏覽器,IE7/IE8顯示的是真實(shí)的字符..., IE9瀏覽器雖然也是CSS3生成,但是是靜態(tài)的,沒有動(dòng)畫效果;此乃漸進(jìn)兼容。
2. 實(shí)現(xiàn)原理
首先HTML非常簡(jiǎn)單,就是一個(gè)標(biāo)簽一個(gè)類名(標(biāo)簽里面一定要空空如也),其他什么都不需要關(guān)心,就可以游刃幾乎各種場(chǎng)景,如下:
XML/HTML Code復(fù)制內(nèi)容到剪貼板
訂單提交中
上面代碼這個(gè)類名為dotting的span就是我們所有的玄機(jī)所在,頁面任意地方,只要有這一小撮HTML就可以有打點(diǎn)動(dòng)畫,與文字混排良好,且顏色自動(dòng)匹配。例如,本文“標(biāo)題一”和“標(biāo)題二”后面的點(diǎn)點(diǎn)點(diǎn)動(dòng)畫就是添加了這么點(diǎn)HTML.
下面是萬眾矚目的CSS代碼了:
CSS Code復(fù)制內(nèi)容到剪貼板
.dotting {
display: inline-block; min-width: 2px; min-height: 2px;
box-shadow: 2px 0 currentColor, 6px 0 currentColor, 10px 0 currentColor; /* for IE9+, ..., 3個(gè)點(diǎn) */
animation: dot 4s infinite step-start both; /* for IE10+, ... */
*zoom: expression(this.innerHTML = '...'); /* for IE7. 若無需兼容IE7, 此行刪除 */
}
.dotting:before { content: '...'; } /* for IE8. 若無需兼容IE8, 此行以及下一行刪除*/
.dotting::before { content: ''; } /* for IE9+ 覆蓋 IE8 */
:root .dotting { margin-right: 8px; } /* for IE9+,FF,CH,OP,SF 占據(jù)空間*/
@keyframes dot {
25% { box-shadow: none; } /* 0個(gè)點(diǎn) */
50% { box-shadow: 2px 0 currentColor; } /* 1個(gè)點(diǎn) */
75% { box-shadow: 2px 0 currentColor, 6px 0 currentColor; /* 2個(gè)點(diǎn) */ }
}
上面每行CSS都有其存在的道理(詳見注釋),這里我們又看到了currentColor這個(gè)關(guān)鍵字,IE9+瀏覽器支持,其可以讓CSS生成的圖形的顏色跟所處環(huán)境的color屬性值一樣,也就是跟文字顏色一樣,具體可參考我不久前寫的“currentColor-CSS3超高校級(jí)好用CSS關(guān)鍵字”一文。
我們動(dòng)畫一個(gè)周期4秒鐘,每秒分別顯示的是0~3個(gè)點(diǎn),使用step-start讓動(dòng)畫不連續(xù)(animation所有關(guān)鍵字“CSS3 animation漸進(jìn)實(shí)現(xiàn)點(diǎn)點(diǎn)點(diǎn)等待提示效果”這篇文章后面深藏詳細(xì)介紹,如有疑問,可參考),于是就有個(gè)類似gif打點(diǎn)動(dòng)畫效果,相信不難理解。
3. 美中不足
雖然幾乎所有瀏覽器都有模有樣,但是,從效果上講,還是有瑕疵的,IE10+以及FireFox瀏覽器下的點(diǎn)的邊緣有些虛(參見下截圖),雖然CSS代碼并沒有設(shè)置盒陰影模糊。這種羽化現(xiàn)象可以讓IE以及FireFox在大數(shù)值盒陰影時(shí)候效果更接近photoshop的陰影效果;但是,在小尺寸陰影時(shí)候,并不是我們想要的。
苛刻的設(shè)計(jì)師、完美主義的處女座顯然是不能對(duì)這個(gè)置若罔聞的。好在,我又想了另外一種方法實(shí)現(xiàn)
基于border + background實(shí)現(xiàn)的打點(diǎn)效果
我們除了可以使用box-shadow生成三個(gè)點(diǎn),還可以使用border + background-color實(shí)現(xiàn)等寬3點(diǎn)效果(如本標(biāo)題)。
您可以狠狠地點(diǎn)擊這里:animation border+background漸進(jìn)實(shí)現(xiàn)打點(diǎn)動(dòng)畫demo
1. 漸進(jìn)兼容
IE9以及IE10+以及FireFox的點(diǎn)再也不是模糊的,而是清清楚楚的小方點(diǎn)!
2. 實(shí)現(xiàn)原理
HTML還是那個(gè)HTML:
XML/HTML Code復(fù)制內(nèi)容到剪貼板
訂單提交中
CSS代碼如下:
CSS Code復(fù)制內(nèi)容到剪貼板
.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 = '...'); /* IE7 */
}
.dotting:before { content: '...'; } /* IE8 */
.dotting::before { content: ''; }
:root .dotting { margin-left: 2px; padding-left: 2px; } /* IE9+ */
@keyframes dot {
25% { border-color: transparent; background-color: transparent; } /* 0個(gè)點(diǎn) */
50% { border-right-color: transparent; background-color: transparent; } /* 1個(gè)點(diǎn) */
75% { border-right-color: transparent; } /* 2個(gè)點(diǎn) */
}
一些說明:
同樣是4秒動(dòng)畫,每秒鐘顯示1個(gè)點(diǎn);
IE7/IE8實(shí)現(xiàn)原理跟上面box-shadow方法一致,都是內(nèi)容生成,如果無需兼容IE7/IE8, 可以按照第一個(gè)例子CSS代碼注釋說明刪除一些CSS;
currentColor關(guān)鍵字可以讓圖形字符化,必不可少;
最大功臣是CSS3 background-clip屬性,可以讓IE9+瀏覽器下左右padding沒有背景色,于是形成了等分打點(diǎn)效果。CSS3 Background博大精深,有興趣可參考一篇很贊的文章“CSS3 Backgrounds相關(guān)介紹”,很多圖,移動(dòng)端非wifi慎點(diǎn);
box-sizing是讓現(xiàn)代瀏覽器和IE7/IE8占據(jù)寬度完全一樣的功臣:IE7/IE8實(shí)際寬度是width+padding-right為12像素,其他現(xiàn)代瀏覽器為width+margin-left也是12像素;
這里CSS代碼主要用來展示原理,故沒有顯示-webkit-animation以及@-webkit-keyframes私有前綴,實(shí)際目前還是需要的;
3. 優(yōu)勢(shì)所在
CSS生成的點(diǎn)沒有虛化,效果更好;
占據(jù)的尺寸各個(gè)瀏覽器完全一致,都是12像素寬度;
顏色繼承;
天然字符化顯示,與文字渾然天成;
到此,相信大家對(duì)“如何使用CSS實(shí)現(xiàn)打點(diǎn)Loading效果”有了更深的了解,不妨來實(shí)際操作一番吧!這里是創(chuàng)新互聯(lián)網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!