5

jQuery 新手,请求帮助解决我无法弄清楚的问题。

克隆的表行包含一个<input type="text" name="dt[]" id="dt1">字段。下面是被克隆的模板行。

<table id="MyTable" name="MyTable">
    <tr name="tr3" id="tr3">
        <td>
            <input type="text" name="dt[]" id="dt1">
        </td>
        <td>
            <input type="file" name="fff[]" id="ff1">
        </td>
    </tr>
</table>

用户可能会创建其中的几个字段,我试图弄清楚如何遍历它们并在提交表单之前验证它们中是否有文本。

请注意,我必须使用 jQuery .on() 方法来访问表单元素。循环需要如何编码?最初,我一直在尝试这个(已编辑):

$(document).on('click','#sub1',function() {
    var d1 = $("[name^=dt]").val();
    alert(d1);
    if (d1 !=""){
        $("#TheForm").submit();
    } else {
        alert("Empty fields!");
    }
});

还有这个:

var d1 = $("#dt1").val();
alert(d1);

还有这个:

var d1 = $("#^dt").val();
alert(d1);

但一直无法获取数据。


编辑:根据要求,此代码克隆该行:

$(document).on('click', '#add_row', function() {
    $("table#MyTable tr:nth-child(4)")
        .clone()
        .show()
        .find("input, span").each(function() {
            $(this)
                .val('')
                .attr('id', function(_, id) {
                    var newcnt = id + count;
                    return id + count;
                    });
        })
        .end()
        .appendTo("table")
        ;

    count++;
    if (count == 2) {
        $('#add_row').prop('disabled', 'disabled');
    }
}); //end add_row Function
4

2 回答 2

14

您的 HTML 格式不正确。你应该做:

<input type="text" name="dt[]">

然后像这样循环:

$('input[name^=dt]').each(function() {
  // code
  alert( this.value ); // $(this).val()
});

您尝试做的事情不能用属性来实现id,但可以用name属性来实现。id应该永远是独一无二的


除此之外

您可以对所有 s 使用通用class名称,input然后像这样循环:

$('input.common_cls').each(function() {
  // code
});

笔记

"#^dt"根本不是一个有效的选择器。正确的语法是

'input[name^=dt]'

或者

input[id^=dt].


您可以执行如下验证

// this function will return true if no empty
// input exists, otherwise it will return false

function noEmptyExists() {
    return $('input[name^=dt]').filter(function() {
        return !$.trim( this.value );
    }).length === 0;
}

$(document).on('click','#sub1',function() {
   if( noEmptyExists() ) {
      alert('Success');
   } else {
      alert('Failed');
   }
});

工作样本


根据进度更新

this.val()是错的。

将此行更改为:

$(this).val()

在 Chat 中讨论并解决克隆问题后

完整代码

$(document).ready(function() {
    var count = 1;
    alert('doc ready');
    var row = $("table#MyTable tr:eq(1)");
    $(document).on('click', '#sub1', function() {
        if (noEmptyExists()) {
            alert('Success');
        } else {
            alert('Failed');
        }
    });

    $(document).on('click', '#add_row', function() {
        row.clone(true).find("input").each(function() {
            $(this).val('').attr('id', function(_, id) {
                var newcnt = id + count;
                return id + count;
            });
        }).end().appendTo("table");
    });

});

function noEmptyExists() {
    return $('input[name^=dt]').filter(function() {
        return !$.trim(this.value);
    }).length === 0;
}

工作样本

于 2012-09-14T19:03:14.770 回答
1

对于任何想知道的人,这是最终代码。thecodeparadox仅因为 HTML 是由 ajax 生成的,所以对 's post进行了轻微修改,这导致了一些细微的差异。正是出于这个原因,我添加了这篇文章,以防其他人正在为同样的问题而苦苦挣扎。不太可能,但是,嘿。

按下提交按钮时 ( <INPUT type="button">)

$(document).on('click', '#sub1', function() {
    var fcnt = 0; //input-FILE
    var dcnt = 0; //input-DOCTITLE
    $('input[name^=fff]').each(function() {
        if($(this).val() == ''){fcnt=fcnt + 1;}
    });
    $('input[name^=dt]').each(function() {
        if($(this).val() == ''){dcnt=dcnt + 1;}
    });
    if (dcnt > 1) {
        alert('Fields marked with an asterisk cannot be empty');
    } else if (fcnt > 1) {
        alert('One of the files is still empty');
    }else{
        $("#TheForm").submit();
    }
});

克隆表行的代码。这是重要的区别,因为我现在明白(感谢 tcp)有必要将行元素分配给 var,然后在 .clone() 方法中使用 var。

$(document).on('click', '#add_row', function() {
    var row = $("table#MyTable tr:eq(3)");
    row.clone(true).find("input").each(function() {
        $(this).val('').attr('id', function(_, id) {
            var newcnt = id + count;
            return id + count;
        });
    }).end().show().appendTo("table");
}); //end add_row Function
于 2012-09-14T22:54:02.760 回答