2012-01-20 64 views
0

我真的在范围的概念挣扎在我的代码。循环内的回调函数

我只是试图创建一个'回调'函数,它将一个className添加到一个变量。因为它在函数内部,所以我使用闭包的概念将全局变量作为参数传递给回调函数(仍然不理解闭包的工作原理)。

var ePressCuttingsArray = $(".cPressCuttings"); 
var eSelectedPressCuttingsArray = []; 
var iIndexArray = []; 
for (var i = 0; i < 7; i++) { 
    var iIndexArrayValue; 
    // two conditions being checked in while loop, if random no. is not in global array (iIndexArray) & i var is equal to eSelectedPress... array 
    while (jQuery.inArray(((iIndexArrayValue = Math.floor(Math.random() * 14) + 1), iIndexArray) === -1) 
     && (i === eSelectedPressCuttingsArray.length)) 
    { 
     // to push a value at a position from array ePressCut... into eSelectedPress... array 
     eSelectedPressCuttingsArray.push(ePressCuttingsArray[iIndexArrayValue]); 
     // run a function to addClass to the recently pushed value in eSelectedPress... array 
     (function (i) { 
      $(eSelectedPressCuttingsArray[i]).addClass("cPressCuttingsDisplay0" + i) 
     } (i)); 
     iIndexArray.push(iIndexArrayValue); 
    } 
} 

有人可以解释为什么关闭功能。没有正确执行,即它总是成功地添加className“cPressCuttingsDisplay00”,但不会在下一次循环迭代时使用“cPressCuttingsDisplay01”的className。

+2

我没有看到任何形式的回调或需要关闭这里。你的匿名函数与你的循环中直接使用它的主体没有任何不同。 – Jacob

+3

你能解释一下这段代码应该做什么吗?我怀疑有一种方法可以简化它。 – Jacob

+1

请注意,只有通过输入函数才能创建变量的新作用域,而不是像for循环或块一样在块内创建。另见:http://bonsaiden.github.com/JavaScript-Garden/#function.closures – GregL

回答

1

您应该能够通过使用for循环来实现自己的目标:

var ePressCuttingsArray = $(".cPressCuttings").makeArray(); 
var eSelectedPressCuttingsArray = []; 
for (var i = 0; i < 7; i++) { 
    var idx = Math.floor(Math.random() * ePressCuttingsArray.length); 
    var selectedItem = ePressCuttingsArray[idx]; 
    selectedItem.addClass('cPressCuttingsDisplay0' + i); 
    eSelectedPressCuttingsArray.push(selectedItem); 
    ePressCuttingsArray.splice(idx, 1); 
} 
+0

谢谢你,正在研究这个。 '不重复同一个号码'的逻辑,我在上面循环时使用了它。这里是修改的代码: (var i = 0; i <7; i ++) {var idx = Math.floor(Math.random()* ePressCuttingsArray.length); (jQuery.inArray(idx,iIndexArray)=== -1) {var selectedItem = ePressCuttingsArray [idx]; $(selectedItem).addClass(“cPressCuttingsDisplay0”+ i); eSelectedPressCuttingsArray.push(selectedItem); iIndexArray.push(idx); } } – Kayote

+0

现在的问题是在while循环中我使用的条件是,如果在数组eSelectedPressCuttingsArray中找不到idx值,则执行表达式的其余部分。但是,现在遇到重复否,它只是通过了否。 &i值继续增加。 虽然也许不是正确的解决方案,但我并没有很好地理解拼接如何解决重复问题... – Kayote

+0

排序它,它不是很优雅,但嘿... \t var ePressCuttingsArray = $(“。cPressCuttings”); \t var iIndexArray = []; (var i = 0; i <6; i ++) \t \t { \t \t var idx = Math.floorrandom()* ePressCuttingsArray.length); \t \t如果(jQuery.inArray(IDX,iIndexArray)=== -1) \t \t { \t \t \t VAR将selectedItem = ePressCuttingsArray [IDX]; \t \t \t $(selectedItem).addClass(“cPressCuttingsDisplay0”+ i); \t \t \t eSelectedPressCuttingsArray.push(selectedItem); \t \t \t iIndexArray.push(idx); \t \t}其他 \t \t { \t \t \t我 - ; \t \t} \t} – Kayote