微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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意味着要传递给每个代码.我已经在上面显示了两个级别的索引(带有描述性名称).

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐