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

前端之家收集整理的这篇文章主要介绍了jquery – setinterval()和clearinterval() – 清除后,不会自动设置动画前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
所以我正在尝试构建一个动画背景图像,它将循环显示一系列图像.

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

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

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

脚本如下:

  1. $(document).ready(function(){
  2.  
  3. var imgArr = new Array(
  4. 'img/slides/slide1.jpg','img/slides/slide2.jpg','img/slides/slide3.jpg');
  5.  
  6. var preloadArr = new Array();
  7. var i;
  8.  
  9.  
  10. // Preload
  11. for(i=0; i < imgArr.length; i++){
  12. preloadArr[i] = new Image();
  13. preloadArr[i].src = imgArr[i];
  14. }
  15.  
  16. var currImg = 1;
  17. var IntID = setInterval(startSlider,4000);
  18.  
  19. // Image Rotator
  20.  
  21. function startSlider(){
  22. $('.mainbg').animate({opacity: 0},1200,"easeInOutExpo",function(){
  23. $(this).css('background','url(' + preloadArr[currImg++%preloadArr.length].src + ') no-repeat center center fixed');
  24. $(this).css({'background-size': 'cover','-webkit-background-size': 'cover','-moz-background-size': 'cover','-o-background-size': 'cover',});
  25. }).animate({opacity: 1},"easeInOutExpo");
  26. }
  27.  
  28. function stopSlider() {
  29. clearInterval(IntID);
  30. }
  31.  
  32. $(".topnav ul li a").click(stopSlider);
  33.  
  34. $("#home").click(startSlider);
  35. });

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

解决方法

这应该为你做.
  1. var IntID = setTimer();
  2.  
  3. function setTimer(){
  4. i = setInterval(startSlider,4000);
  5. return i;
  6. }
  7.  
  8. function stopSlider() {
  9. clearInterval(IntID);
  10. }
  11.  
  12. //Restart Timer
  13. // Option 1 make a restartSlider function and call it
  14. $("#home").click(restartSlider);
  15. function restartSlider(){
  16. IntID = setTimer();
  17. }
  18.  
  19. //Option 2 create an anonymous function only for that click event.
  20. $("#home").click(function(){
  21. IntID = setTimer();
  22. });

猜你在找的jQuery相关文章