-1

我已经编写了这段代码,这是 jquery 中的一个基本图片库

$(document).ready(function() {
 setInterval("rotateImages()",2000)
 })

function rotateImages() {
     var curPhoto = $("#photoshow div.current");
     var nextPhoto = curPhoto.next();
     if (nextPhoto.length == 0) {
         nextPhoto = $("#photoshow div:first");
     }
     curPhoto.removeClass("current").addClass("previous");
     nextPhoto.css({
         opacity: 0.0
     }).addClass("current").animate({
         opacity: 1.0
     }, 1000‌​, function () {
         curPhoto.removeClass("previous")
     });
}

这有效,除非我用 {} 包装 if 语句,但它没有。我只是想了解两者之间的区别以及为什么它不起作用。

4

2 回答 2

1

多行需要 {},否则 javascript 解释器不知道它还有更多的东西要运行。

试试这个,它必须工作:

$(document).ready(function() {
    setInterval("rotateImages()", 2000);
})

function rotateImages() {
    var curPhoto = $("#photoshow div.current")
    var nxtPhoto = curPhoto.next();

    if (nxtPhoto.length == 0) {
        nxtPhoto = $("#photoshow div:first");
        curPhoto.removeClass('current').addClass('previous');
        nxtPhoto.css({
            opacity: 0.0
        }).addClass('current').animate({
            opacity: 1.0
        }, 1000, function() {
            curPhoto.removeClass('previous');
        });
    }
}

PS 也请使用分号 (;) 来区分行。

于 2011-08-12T16:14:58.253 回答
0

如果一个 if 语句只有一个应该有条件地执行的语句,你可以去掉大括号。如果必须有条件地执行更多语句,则必须将它们作为大括号内的代码块包含在内。我的提示:总是写一对大括号,尤其是。如果你开始编程!

于 2011-08-12T16:10:53.517 回答