微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

jquery – setinterval()和clearinterval() – 清除后,不会自动设置动画

所以我正在尝试构建一个动画背景图像,它将循环显示一系列图像.

我们的想法是,当您单击页面上的任何导航元素时,循环将暂停.

单击主页按钮时,循环将再次启动(从当前图像).

这在它的当前状态下工作,但是在重新触发它时循环不是自动的,而是你必须按下每个淡入淡出/滑动/任何东西的主页按钮.

脚本如下:

$(document).ready(function(){

    var imgArr = new Array(
        'img/slides/slide1.jpg','img/slides/slide2.jpg','img/slides/slide3.jpg');

    var preloadArr = new Array();
    var i;


    // Preload
    for(i=0; i < imgArr.length; i++){
        preloadArr[i] = new Image();
        preloadArr[i].src = imgArr[i];
    }

    var currImg = 1;
    var IntID = setInterval(startSlider,4000);

    // Image rotator

    function startSlider(){
        $('.mainbg').animate({opacity: 0},1200,"easeInOutExpo",function(){
            $(this).css('background','url(' + preloadArr[currImg++%preloadArr.length].src + ') no-repeat center center fixed');
            $(this).css({'background-size': 'cover','-webkit-background-size': 'cover','-moz-background-size': 'cover','-o-background-size': 'cover',});
            }).animate({opacity: 1},"easeInOutExpo");
        }

    function stopSlider() {
        clearInterval(IntID);
    }

    $(".topnav ul li a").click(stopSlider);

    $("#home").click(startSlider);
});

如果有人能指出我正确的方向,我们将不胜感激!最好的问候,卡斯帕.

解决方法

这应该为你做.
var IntID = setTimer();

function setTimer(){
     i = setInterval(startSlider,4000);
     return i;
}

function stopSlider() {
    clearInterval(IntID);
}

//Restart Timer
// Option 1 make a restartSlider function and call it
$("#home").click(restartSlider);
function restartSlider(){
      IntID = setTimer();
}

//Option 2 create an anonymous function only for that click event.
$("#home").click(function(){
     IntID = setTimer();
});

原文地址:https://www.jb51.cc/jquery/181360.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐