jQuery幻灯片放映时间?

时间:2013-07-24 23:58:47

标签: javascript jquery slideshow

我最近得到了一个简单的幻灯片代码,我试图调整图片在显示之前显示的时间。我玩过不同的变量,但我似乎无法让它停留超过6秒,这是一种侮辱。我希望它显示约15秒。这是我第一次遇到javascript所以请耐心等待。如果有人能够指出我需要做些什么才能延长时间,我将非常感激。感谢Advanced,Josh

以下是javascript代码:

(function($){  

$.fn.s3Slider = function(vars) {       

    var element     = this;
    var timeOut     = (vars.timeOut != undefined) ? vars.timeOut : 4000;
    var current     = null;
    var timeOutFn   = null;
    var faderStat   = true;
    var mOver       = false;
    var items       = $("#" + element[0].id + "Content ." + element[0].id + "Image");
    var itemsSpan   = $("#" + element[0].id + "Content ." + element[0].id + "Image span");

    items.each(function(i) {

        $(items[i]).mouseover(function() {
           mOver = true;
        });

        $(items[i]).mouseout(function() {
            mOver   = false;
            fadeElement(true);
        });

    });

    var fadeElement = function(isMouseOut) {
        var thisTimeOut = (isMouseOut) ? (timeOut/2) : timeOut;
        thisTimeOut = (faderStat) ? 10 : thisTimeOut;
        if(items.length > 0) {
            timeOutFn = setTimeout(makeSlider, thisTimeOut);
        } else {
            console.log("Poof..");
        }
    }

    var makeSlider = function() {
        current = (current != null) ? current : items[(items.length-1)];
        var currNo      = jQuery.inArray(current, items) + 1
        currNo = (currNo == items.length) ? 0 : (currNo - 1);
        var newMargin   = $(element).width() * currNo;
        if(faderStat == true) {
            if(!mOver) {
                $(items[currNo]).fadeIn((timeOut/6), function() {
                    if($(itemsSpan[currNo]).css('bottom') == 0) {
                        $(itemsSpan[currNo]).slideUp((timeOut/6), function() {
                            faderStat = false;
                            current = items[currNo];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    } else {
                        $(itemsSpan[currNo]).slideDown((timeOut/6), function() {
                            faderStat = false;
                            current = items[currNo];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    }
                });
            }
        } else {
            if(!mOver) {
                if($(itemsSpan[currNo]).css('bottom') == 0) {
                    $(itemsSpan[currNo]).slideDown((timeOut/6), function() {
                        $(items[currNo]).fadeOut((timeOut/6), function() {
                            faderStat = true;
                            current = items[(currNo+1)];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    });
                } else {
                    $(itemsSpan[currNo]).slideUp((timeOut/6), function() {
                    $(items[currNo]).fadeOut((timeOut/6), function() {
                            faderStat = true;
                            current = items[(currNo+1)];
                            if(!mOver) {
                                fadeElement(false);
                            }
                        });
                    });
                }
            }
        }
    }

    makeSlider();

};  

})(jQuery);  

2 个答案:

答案 0 :(得分:1)

var timeOut     = (vars.timeOut != undefined) ? vars.timeOut : 4000;

上面的代码片段设置当前超时时间(4s),然后将在下面的函数中使用。

我不在电脑前测试这个。

尝试增加该值,看看它是否有效。

答案 1 :(得分:0)

在html标记的<head>部分执行此操作:

<script type="text/javascript">  // This is the script for the banner slider
    $(document).ready(function() {
        $('slider class= or id= name').s3Slider({
        timeOut: 6500
        });
    });
</script>

更改timeOut的值将更改幻灯片图像显示的时间长度(以毫秒为单位)。在上面的示例中,每个图像将显示6.5秒。