首頁 > web前端 > H5教程 > 主體

HTML5/CSS3 網頁載入進度條的實現,下載進度條等經典案例

黄舟
發布: 2017-03-10 16:15:41
原創
2451 人瀏覽過

今天帶給大家一個比較炫的進度條,進度條在一耗時操作上給用戶一個比較好的體驗,不會讓用戶覺得在盲目等待,對於沒有進度條的長時間等待,用戶會任務死機了,毫不猶豫的關掉應用;一般用於下載任務,刪除大量任務,網頁加載等;如果有使用html5為手機佈局的,也可以用於手機中~

#效果圖:

1、html結構:

 <p id="loadBar01" class="loadBar">
        <p>
             <span class="percent">
                <i></i>
             </span>
        </p>
        <span class="percentNum">0%</span>
    </p>
登入後複製

#簡單分析下:
p.loadBar代表整個進度列

p .loadBar p 設定了圓角錶框,p.loadBar p  span 為進度(動態改變寬度),  p.loadBar p  span i 為進度填滿背景色(即width=100%)

HTML的結構,大家可以自己設計,只要合理,都沒有問題~

2、CSS:

 body
        {
            font-family: Thoma, Microsoft YaHei, &#39;Lato&#39;, Calibri, Arial, sans-serif;
        }

        #content
        {
            margin: 120px auto;
            width: 80%;
        }

        .loadBar
        {
            width: 600px;
            height: 30px;
            border: 3px solid #212121;
            border-radius: 20px;
            position: relative;
        }

        .loadBar p
        {
            width: 100%;
            height: 100%;
            position: absolute;
            top: 0;
            left: 0;
        }

        .loadBar p span, .loadBar p i
        {
            box-shadow: inset 0 -2px 6px rgba(0, 0, 0, .4);
            width: 0%;
            display: block;
            height: 100%;
            position: absolute;
            top: 0;
            left: 0;
            border-radius: 20px;
        }

        .loadBar p i
        {
            width: 100%;
            -webkit-animation: move .8s linear infinite;
            background: -webkit-linear-gradient(left top, #7ed047 0%, #7ed047 25%, #4ea018 25%, #4ea018 50%, #7ed047 50%, #7ed047 75%, #4ea018 75%, #4ea018 100%);
            background-size: 40px 40px;
        }

        .loadBar .percentNum
        {
            position: absolute;
            top: 100%;
            right: 10%;
            padding: 1px 15px;
            border-bottom-left-radius: 16px;
            border-bottom-right-radius: 16px;
            border: 1px solid #222;
            background-color: #222;
            color: #fff;

        }

        @-webkit-keyframes move
        {
            0%
            {
                background-position: 0 0;
            }
            100%
            {
                background-position: 40px 0;
            }
        }
登入後複製


此時效果為:



整體佈局就是利用position relative和absolute~

比較難的地方就是,漸變條的實作:

我們採用

a、由左上到右下的漸變

b、顏色分別為:0-25% 為#7ed047 , 25%-50% 為#4ea018 , 50%-75%為# 7ed047 , 75%-100%為#4ea018

c、背景的大小為40px 40px 這個設定超過高度就行, 越大,條文寬度越寬 

分析圖:


#設定的原理就是上圖了,同時可以背景寬度設定越大,條文寬度越大;

3、設定Js,建立LoadBar物件

 function LoadingBar(id)
        {
            this.loadbar = $("#" + id);
            this.percentEle = $(".percent", this.loadbar);
            this.percentNumEle = $(".percentNum", this.loadbar);
            this.max = 100;
            this.currentProgress = 0;
        }
        LoadingBar.prototype = {
            constructor: LoadingBar,
            setMax: function (maxVal)
            {
                this.max = maxVal;
            },
            setProgress: function (val)
            {
                if (val >= this.max)
                {
                    val = this.max;
                }
                this.currentProgress = parseInt((val / this.max) * 100) + "%";
                this.percentEle.width(this.currentProgress);
                this.percentNumEle.text(this.currentProgress);


            }
        };
登入後複製


我們建立了一個LoadBar對象,同時公開了兩個方法,一個設定最大進度,一個設定當下進度;例如下載檔案最大進度為檔案大小,當前進度為已下載檔案大小。

4、測試

最後我們測試下我們的程式碼:

   $(function ()
        {

            var loadbar = new LoadingBar("loadBar01");
            var max = 1000;
            loadbar.setMax(max);
            var i = 0;
            var time = setInterval(function ()
            {
                loadbar.setProgress(i);
                if (i == max)
                {
                    clearInterval(time);
                    return;
                }
                i += 10;
            }, 40);
        });
登入後複製

以上是HTML5/CSS3 網頁載入進度條的實現,下載進度條等經典案例的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
最新問題
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!