繁体   English   中英

用于PHP或HTML的基于文本的进度栏

[英]Text Based Progress Bar for PHP or HTML

嗨,我正在寻找一个基于文本的进度条,它通过运行“ =====”并给出百分比来显示进度。

类似于这样的进度条http://scott.sherrillmix.com/blog/programmer/progress-bars-in-r/

但应该在php中,如下所示

============================================= 99%

当我们刷新页面或单击网页上的任何按钮提交时,进度条应显示页面加载的进度。

我认为您必须使用jquerycss处理此工作,以便可以用于phphtml或所需的任何网页。

这是我的解决方案DEMO LINK

HTML:

<div id="content">
    <h1>Preloading site</h1>
    <ul>
        <li><img src="images/a.jpg" alt="Flower" /></li>
        .
        .
        .
        <li><img src="images/z.jpg" alt="Flowers" /></li>
    </ul>

</div>

CSS:

body {
    background-color: #000;
    margin: 0px;
    padding: 0px;
    background-image: url(../images/lotus.jpg);
    background-position: 50% 50%;
    background-attachment: fixed;
    font-family: sans-serif;
    font-size: 14px;
}

p {
    line-height: 1.4em;
}

img{
    max-width:100%;
}

body #content {
    width: 800px;
    padding: 20px;
    background-color: rgba(255,255,255,.6);
    margin: 20px auto;
    overflow: hidden;
}

h1{
    font-family: georgia;
    font-style: italic;
    color:maroon;
}

body ul {
    padding: 0px;
    margin: 0px;
}

body ul li {
    display: block;
    list-style-type: none;
    float: left;
    width: 400px;
    height: auto;
    overflow: hidden;
    text-align: center;
}

body ul li.gradient {
    padding: 20px;
    width: 360px;
    height: 227px;

    background: #efc5ca; /* Old browsers */
    background: -moz-linear-gradient(top, #efc5ca 0%, #ef2f43 100%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#efc5ca), color-stop(100%,#ef2f43)); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(top, #efc5ca 0%,#ef2f43 100%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(top, #efc5ca 0%,#ef2f43 100%); /* Opera 11.10+ */
    background: -ms-linear-gradient(top, #efc5ca 0%,#ef2f43 100%); /* IE10+ */
    background: linear-gradient(top, #efc5ca 0%,#ef2f43 100%); /* W3C */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#efc5ca', endColorstr='#ef2f43',GradientType=0 ); /* IE6-9 */
}
#loaderMask{
    text-align: center;
    padding-top: 20%;
}
#loaderMask span{
    padding: 20px;
    float:left;
    font-size: 12px;
    font-weight:bold;

}

剧本:

$(document).ready(function () {
    "use strict"
    //indexOf is not supported by IE9>. 
    if (!Array.prototype.indexOf){
      Array.prototype.indexOf = function(elt /*, from*/){
        var len = this.length >>> 0;

        var from = Number(arguments[1]) || 0;
        from = (from < 0)
             ? Math.ceil(from)
             : Math.floor(from);
        if (from < 0)
          from += len;

        for (; from < len; from++){
          if (from in this &&
              this[from] === elt)
            return from;
        }
        return -1;
      };
    }

    var bgImg = [], img = [], count=0, percentage = 0;

    //Creating loader overlay
    $('<div id="loaderMask"><span>0%</span></div>').css({
        position:"fixed",
        top:0,
        bottom:0,
        left:0,
        right:0,
        background:'#fff'
    }).appendTo('body');

    //Searching all elemnts in the page for image
    $('*').filter(function() {

        var val = $(this).css('background-image').replace(/url\(/g,'').replace(/\)/,'').replace(/"/g,'');
        var imgVal = $(this).not('script').attr('src');

        if(val !== 'none' && !/linear-gradient/g.test(val) && bgImg.indexOf(val) === -1){
            bgImg.push(val)
        }

        if(imgVal !== undefined && img.indexOf(imgVal) === -1){
            img.push(imgVal)
        }

    });

    var imgArray = bgImg.concat(img); 

    $.each(imgArray, function(i,val){ //Adding load and error event
        $("<img />").attr("src", val).bind("load", function () {
            completeImageLoading();
        });

        $("<img />").attr("src", val).bind("error", function () {
            imgError(this);
        });
    })

    function completeImageLoading(){
        count++;
        percentage = Math.floor(count / imgArray.length * 100);
        $('#loaderMask').html('<span>'+percentage + '%'+'</span>');
        for ( var i = 0; i < percentage; i++ ) {
            $('#loaderMask span').append("=");
            }
        if(percentage === 100){
            $('#loaderMask').html('<span>100%</span>')
            $('#loaderMask').fadeOut(function(){
                $('#loaderMask').remove()
            })
        }
    }

    //Error handling
    function imgError (arg) {
        $('#loaderMask').html("Image failed to load.. Loader quitting..").delay(3000).fadeOut(1000, function(){
            $('#loaderMask').remove();
        })
    }    
});

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM