2011-10-13 11 views
8

¿Cómo puedo crear una matriz desde el interior del ".each loop" y usarla fuera del ciclo?Cómo crear una matriz a partir de .each loop con jQuery

Mi .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 

     }); 

¿Cómo puedo crear una matriz de todo var = ClassesToApply?

¿Y cómo puedo hacer algo con esta matriz? por ejemplo

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

+0

obtendrá una matriz de cadenas. ¿Qué quieres hacer con una matriz así? Los métodos jQuery se realizan en matrices que contienen elementos DOM, no cadenas. –

+0

Estoy buscando utilizar una cadena como selector para mostrar/ocultar elemento con LAS MISMAS clases en diferentes div. Filtrado - más o menos. – Iladarsda

Respuesta

21

Si se declara una variable fuera de la each, será accesible en el interior del 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. 

Aunque como otros han demostrado, hay formas de acortar su código de manera significativa .

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

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

Se podría hacer:

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

¡Gran ejemplo! Nunca utilicé '.map' antes, necesito verlo. – Iladarsda

+0

Si OP quiere una matriz, no olvide encadenar '.get()' o '.toArray()' después de '.map()'. – user113716

+1

@ Ӫ _._ Ӫ Olvidé eso, gracias. –

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; 
     } 
    } 
Cuestiones relacionadas