jQuery每一个

时间:2011-06-20 09:14:23

标签: javascript jquery

var slides = $(".promo-slide");
slides.each(function(key, value){
    if (key == 1) {
        this.addClass("first");
    }
});

为什么我会收到错误消息:

Uncaught TypeError: Object #<HTMLDivElement> has no method 'addClass'

从上面的代码?

2 个答案:

答案 0 :(得分:20)

在jQuery回调函数中,this指的是DOM对象,而不是jQuery对象。

var slides = $(".promo-slide");
slides.each(function(key, value){
    if (key == 0) { // NOTE: the key will start to count from 0, not 1!
        $(this).addClass("first");
//------^^----^       
    }
});

但是:在你的情况下,这更容易:

$(".promo-slide:first").addClass("first");

顺便说一句,我认为为包含带有$的jQuery对象的变量添加前缀是一个有用的约定:

var $slides = $(".promo-slide");
$slides.each( /* ... */ );

答案 1 :(得分:2)

您可能想要这样做:

$(this).addClass