Jquery进度条:实施进度条的问题

时间:2014-11-29 01:33:16

标签: javascript jquery jquery-ui progress-bar jquery-ui-progressbar

我在使用jquery UI progressbar小部件实现进度条时遇到问题。窗口小部件中的实际栏未实时加载。当计时器完成时,它会跳到结束条。我不确定为什么这样做。任何帮助表示赞赏

$(document).ready(function() {
    $("#start_timer").click(
        function () {
            var totalTime = $("#time").val();
            var interval = $("#interval").val();
            var isValid = true;

        $("#progressbar").progressbar({
                value:0
        });

        // validate the time
        if (totalTime == "") { 
            $("#time_error").text("This field is required.");
            isValid = false;
        } else if (isNaN(totalTime)) {
            $("#time_error").text("Time must be a number.");
            isValid = false;
        } else {
            $("#time_error").text("");
        } 

        // validate the interval
        if (interval == "") { 
            $("#interval_error").text("This field is required.");
            isValid = false;
        } else if (isNaN(interval)) {
            $("#interval_error").text("Interval must be a number.");
            isValid = false;
        } else {
            $("#interval_error").text("");
        }

        if (isValid) {
            totalTime = totalTime * 1000;
            interval = interval * 1000;
            var elapsedTime = 0;
            var displayMinutes = 0;
            var displaySeconds = 0;


            var timer = setInterval(
                function () {
                    elapsedTime += interval;
                    displaySeconds = elapsedTime / 1000;

                    $("#progressbar").progressbar("value", elapsedTime);

                    /*if (displaySeconds < 60) {
                        $("#elapsed").val(displaySeconds + " seconds");
                    } else {                                
                        displayMinutes = parseInt(displaySeconds / 60);
                        displaySeconds = displaySeconds % 60;
                        if (displaySeconds == 0) {
                            $("#elapsed").val(displayMinutes + " minutes");                                 
                        } else {
                            $("#elapsed").val(displayMinutes + " minutes " + displaySeconds + " seconds");                                  
                        }
                    }
                    if (elapsedTime == totalTime) {
                        clearInterval(timer);
                        $("#complete span").text("Time is up!")
                    }*/ 
                },
                interval );


        }
    }
);
$("#totalTime").focus();

});

0 个答案:

没有答案