2011-10-13 28 views
8

'.each loop' içinden bir dizi nasıl oluşturabilirim ve onu döngü dışında kullanabilirim?jQuery ile bir döngü oluşturma nasıl oluşturulur?

Benim .each loop:

 // Loop through all but button with class .apply 
     $('.profile-nav ul li a').not('.apply').each(function() { 

      // if currently loop through element has .cur class 
      if($(this).hasClass('cur')) { 


       //Get the first class of the match element     
       var ClassesToApply = $(this).prop('class').split(' ')[0]; 

      } 
      //How can I create an array from all ClassesToApply? 


      //var arr = jQuery.makeArray(ClassesToApply); 
      // This will create an array, but with one element only 

     }); 

nasıl bütün var = ClassesToApply bir dizi oluşturabilir?

Ve bu diziyle nasıl bir şey yapabilirim? örn

$(allClasses from an array as a selectors).doStuff();

+0

Sen dizelerden oluşan bir dizi alacak. Böyle bir diziyle ne yapmak istersin? jQuery yöntemleri dizeleri değil, DOM öğelerini içeren dizilerde gerçekleştirilir. –

+0

Dizgiyi farklı div içindeki THE SAME sınıflarıyla gösterme/gizleme için seçici olarak kullanmayı düşünüyorum. Filtreleme - sıralama. – Iladarsda

cevap

21

Eğer each dışında bir değişken bildirirseniz, içinde erişilebilir olacak each:

var yourArray = []; 
$('.profile-nav ul li a').not('.apply').each(function() { 
    if($(this).hasClass('cur')) { 
     yourArray.push($(this).prop('class').split(' ')[0]); 
    } 
}); 
//Here, yourArray will contain the strings you require. 

diğerleri gösterdiği gibi, önemli ölçüde kodunuzu kısaltmak için yollar bulunmasına rağmen .

0
var list = $(".profile-nav ul li a.cur:not(.apply)"); 

list.each(function(){ 
    // do your thing! 
}); 
6

Sen yapabilirdi:

var arr = $('a.cur:not(.apply)', '.profile-nav').map(function() { 
    return $(this).prop('class').split(' ')[0]; 
}).get(); 
+0

Harika bir örnek! Daha önce hiç kullanmamıştım, ona bakmam lazım. – Iladarsda

+0

OP'nin bir Dizi olması durumunda, '.map()' den sonra '.get()' ya da '.toArray() işlevlerini zincirlemeyi unutmayın. – user113716

+1

@ Ӫ _._ Ӫ Bunu unuttum, teşekkürler. –

13
fxnReqValidation = function() { 
     var InputTagArray = new Array; 
     InputTagArray = document.getElementsByTagName("input"); 
     for (var iCnt = 1; iCnt <= InputTagArray.length; iCnt++) { 
      if ((g_Json[InputTagArray[iCnt].name].required == true) && (InputTagArray[iCnt].value == "")) { 
       $("#errormsg").text("please enter all required fields"); 
      } 
      return false; 
     } 
    } 
İlgili konular