2

所以我试图将一个数组输入到一个 jquery 选择器中,由于某种原因我根本无法让它工作。我尝试了以下第一种方法:

var id = ["#id1", "#id2", "#id3"];
$(id[0]).css('color', '#000');

我的另一个尝试:

var id = [];
for(var x = 0;x < 3; x++){
id[x] = x;
$("#id"+id[0]).css('color', '#000');
}

所以我想知道解决这个问题的方法可能是什么?

我使用它的例子:

for(var x = 0;x < 28; x++){
function randomizerlet(){
randlet[x] = Math.floor(Math.random()*156);
timesletrun[x] += 1;
if (masterlet[randlet[x]] == letter[x]){
$('#flipL4_1').css('background-position', masterlet[randlet[x]]);
clearInterval(intervallet[x]);
}
else{
    if(timesletrun[x] == 300){
        masterlet[randlet[x]] = letter[x];
        $('#flipL4_1').css('background-position', masterlet[randlet[x]]);
        clearInterval(intervallet[x]);
        }
    else{
        $('#flipL4_1').css('background-position', masterlet[randlet[x]]);
        }}


        }
var intervallet[x] = setInterval(function() {
 randomizerlet();}, 10);
}
4

1 回答 1

5

将数组元素连接成一个字符串:

var id = ["#id1", "#id2", "#id3"];
$(id.join(',')).css('color', '#000');

或使用循环:

for (var i=0; i<id.length; i++) {
    $(id[i]).css(...);
}

或另一种循环:

$.each(id, function (i, elt) {
    $(elt).css(...);
});

或者更花哨的循环:

var $elements = $.map(id, function (elt, i) {
    return $(elt);
});
$elements.css(...);

综上所述,使用通用类而不是 ID 可能会更好。任何时候你认为你需要类似数字的索引,这强烈暗示你最好使用类来代替。

于 2013-04-01T04:03:55.203 回答