HTML5 CSS3 誘人的實例 : 網頁加載進度條的實現,下載進度條等

jopen 8年前發布 | 17K 次閱讀 HTML5 前端技術

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

效果圖:

1、html結構:

<div id="loadBar01" class="loadBar">
        <div>
             <span class="percent">
                <i></i>
             </span>
        </div>
        <span class="percentNum">0%</span>
    </div>
簡單分析下:
div.loadBar代表整個進度條

div.loadBar div 設置了圓角表框 ,div.loadBar div  span 為進度 (動態改變寬度),  div.loadBar div  span i 為進度填充背景色(即width=100%)

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

2、CSS:

body
        {
            font-family: Thoma, Microsoft YaHei, 'Lato', 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 div
        {
            width: 100%;
            height: 100%;
            position: absolute;
            top: 0;
            left: 0;
        }

        .loadBar div span, .loadBar div 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 div 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);
        });

ps:對于js對象的設計,盡可能的考慮實用性~

最后完工~哈~ 吃飯吃飯~ 


源碼點擊下載

來自: http://blog.csdn.net//lmj623565791/article/details/34825865

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!