我使用以下教程为我的网站制作视差内容滑块:http://blog.themeforest.net/tutorials/create-a-funky-parallax-background-effect-using-jquery/
我得到了很好的工作,但想要添加自动滚动功能。我是通过添加jQuery.serialScroll和使用setInterval来实现的,但它现在就像疯了一样。我想滑块现在每隔5秒就会经过3个幻灯片,而不是每5秒1个幻灯片。我不知道如何让它正常工作。
以下是我的HTML的一部分:
<body>
<div id="header">
<h1 id="logo">Testing slider</h1>
</div>
<!-- end logo -->
<div id="slider">
<div id="background">
<div id="bg">
</div>
</div>
<!-- end slide background -->
<div id="wrapper">
<ul id="mask">
<li id="box1" class="box">
<a name="box1"><img src="images/slide1.png"></a>
<div class="content">
<div class="inner">
</div>
</div>
</li>
<!-- end box1 -->
<li id="box2" class="box">
<a name="box2"><img src="images/slide2.png"></a>
<div class="content">
<div class="inner">
</div>
</div>
</li>
<!-- end box2 -->
<li id="box3" class="box">
<a name="box3"><img src="images/slide3.png"></a>
<div class="content">
<div class="inner">
</div>
</div>
</li>
<!-- end box3 -->
</ul>
<!-- end mask -->
</div>
<!-- end wrapper -->
</div>
<!-- end Slider -->
<div id="content">
<div id="menu">
<ul id="menuitem">
<li><a href="#box1" class="slide_next"></a></li>
<li><a href="#box2" class="slide_next"></a></li>
<li><a href="#box3" class="slide_next"></a></li>
</ul>
</div>
<!-- end menu -->
</div>
<!-- end content -->
这是令人不安的JS代码:
<script type="text/javascript">
$(document).ready(function() {
$('a.slide_next').click(function () {
$('#wrapper').scrollTo($(this).attr('href'), 800);
setPosition($(this).attr('href'), '#background', '0px', '50px', '100px')
$('a.slide_next').removeClass('selected');
$(this).addClass('selected');
return false;
});
});
setInterval(function() {$('a.slide_next').click()}, 5000);
function setPosition(check, div, p1, p2, p3) {
if(check==='#box1')
{ $(div).scrollTo(p1, 800); }
else if(check==='#box2')
{ $(div).scrollTo(p2, 800); }
else
{ $(div).scrollTo(p3, 800); }
};
</script>
拜托,任何人都知道如何让它按照应有的方式工作(每5秒1张幻灯片)?
PS。请你好,我是该领域的新人;)
答案 0 :(得分:1)
我认为你的问题是你每隔5秒触发所有3个“下一张幻灯片”链接上的点击事件,所以它会逐渐尝试为每张幻灯片执行你的onclick代码。
你能做的是这样的事情:
//set a global var to keep track of the slide we're on
window.slide = 1
function nextSlide(){
//increase window.slide by 1 (to go to the next slide),
//or if it is 3 return to the first slide
window.slide == 3 ? window.slide = 1 : window.slide++;
//trigger click event on the NEXT slide only
$('a[href=#box'+window.slide+']').click()
}
setInterval(nextSlide,5000);
这样,每隔5秒就会触发链接上的单击事件以移动到NEXT幻灯片(而不是全部)。
希望这有帮助!