jquery追加行onclick

时间:2010-04-24 17:58:37

标签: jquery append row

**编辑---尝试更简化的版本....仍然无效...返回$(this).closest不是函数错误... **

$("#fitable input[name^=f1]").focus(function() {
        var newRow = '<tr><td></td><td></td><td></td><td></td></tr>';
        $(this).closest("tbody").append(newRow);
    });

原帖

jQuery很新,所以我希望有人可以帮助我...这里有几件事情......对它的任何部分的帮助表示赞赏。

对于初学者,当用户点击该行的第一个启用输入字段时,我正在尝试向表中追加一行。这是我正在尝试使用的代码:

    $("#fitable > tbody > tr > td > input").bind('focus', function() {
        if($(this).attr('disabled', false)) {
            $(this).click(function() {
                    var newRow = '<tr><td><input name="f1[]" value="" /><label>CustNew</label></td><td><input name="field_n1[]" value="" /><label>N1</label></td><td><input name="field_n2[]" value="" /><label>N2</label></td></tr>';
                    $(this).closest("tbody").append(newRow);
            });
        }
    });

如果它有用,这是html:

<table id="fitable">
    <tbody>
        <tr valign="top">
            <td><input disabled="disabled" name="cust" id="edit-cust" value="sample@sample.com" type="text"><label>Cust</label></td>
            <td><input name="field_n1[]" value="" type="text"><label>N1</label></td>
            <td><input name="field_n2[]" value="" type="text"><label>N2</label></td>
        </tr>
    </tbody>
</table>

3 个答案:

答案 0 :(得分:1)

我认为你的if语句将clicked属性设置为false。试试这个:

if( $( this ).attr( 'disabled' ) == false ) {
    // do stuff
}

答案 1 :(得分:0)

试试这个:

$("#fitable input").focus(function() {
        if($(this).attr('disabled', false)) {
            $(this).click(function() {
                    var newRow = '<tr><td><input name="f1[]" value="" /><label>CustNew</label></td><td><input name="field_n1[]" value="" /><label>N1</label></td><td><input name="field_n2[]" value="" /><label>N2</label></td></tr>';
                    $(this).closest("tbody").append(newRow);
            });
        }
    });

答案 2 :(得分:0)