所以我试图将一个数组输入到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);
}
答案 0 :(得分: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可能会更好。任何时候你认为你需要类似数字的索引,这是一个强烈的暗示,你最好不要使用类。