javascript – 我们可以在jquery中的.each中使用.each吗?

前端之家收集整理的这篇文章主要介绍了javascript – 我们可以在jquery中的.each中使用.each吗?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
$("[name=form_1]").each(function(){
    alert("i in else"+i);
    $('.eform_text').each(function() {
    });
});

这个循环会迭代所有只有form1的eform_text类的元素.或者它会遍历所有拥有该类的元素吗?

更新:

确切的jsp代码如下:

< c:when test =“${eformDetails.controlType == 1}”>
< input id =“textBox _ ${eformDetails.id} _ ${eformDetails.required} _ ${i}”class =“eformDetail eform_text”type =“text”value =“”name =“form _ ${i}”的onblur = “validateEformInputs(${I-1})” >< /输入>
< / C:当>

我有每次变化的形式.对于每个表格,我需要获得所有的文本框.目前在你的帮助后我的javascript是屁股跟随:

$(“[name = form_”i“]”).each(function(i){
警报(“我在其他地方”);

$('.eform_text',this).each(function() {
        textBoxId = $(this).attr("id");

它到达第一个警报,但我无法到达第二个循环.它没有获得具有类eform_text的元素.不知道这里出了什么问题.你能帮忙吗?

解决方法

它将遍历具有该类的所有元素,无论是否在名称为“form_1”的表单内.要仅查看每个表单(我猜你必须有多个名称为“form_1”的表单,尽管这看起来很奇怪),在外部循环中使用 find以限定内部循环:
$("[name=form_1]").each(function(formIndex) {
    alert("formIndex in each: " + formIndex);
    $(this).find('.eform_text').each(function(textIndex) {
        alert("textIndex in each: " + textIndex);
    });
});

或者你可以使用$()的第二个参数,它提供了工作的上下文:

$("[name=form_1]").each(function(formIndex) {
    alert("formIndex in each: " + formIndex);
    $('.eform_text',this).each(function(textIndex) {
        alert("textIndex in each: " + textIndex);
    });
});

要么应该工作.

请注意,正如@Shrikant Sharat在评论中指出的那样(感谢Shrikant!),我假设原始代码中的i意味着要传递给每个代码.我已经在上面显示了两个级别的索引(带有描述性名称).

猜你在找的jQuery相关文章