我有一个带有循环的轮播图像的脚本
$(document).ready(function() {
//rotation speed and timer
var speed = 5000;
var run = setInterval(rotate(), speed);
//grab the width and calculate left value
var item_width = $('#slides li').outerWidth();
var left_value = item_width * (-1);
//move the last item before first item, just in case user click prev button
$('#slides li:first').before($('#slides li:last'));
//set the default item to the correct position
$('#slides ul').css({'left' : left_value});
//if user clicked on next button
function rotate() {
//get the right position
var left_indent = parseInt($('#slides ul').css('left')) - item_width;
//slide the item
$('#slides ul').animate({'left' : left_indent}, 3000, function () {
//move the first item and put it as last item
$('#slides li:last').after($('#slides li:first'));
//set the default item to correct position
$('#slides ul').css({'left' : left_value});
});
//cancel the link behavior
return false;
}
});
但我在 firebug 中收到这个 javascript 错误:
无用的 setInterval 调用(参数周围缺少引号?)
[Interrompi per questo errore] var run = setInterval(rotate(), speed);
我认为这是旋转函数定义的错误!
这意味着你应该写:
var run = setInterval(rotate, speed);
代替
var run = setInterval(rotate(), speed);
因为你需要将函数的引用传递给setInterval,所以你传递的是函数rotate()的返回值;
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)