JQuery добавить строку по клику - PullRequest
2 голосов
/ 24 апреля 2010

** EDIT --- Попытка еще более упрощенной версии .... Все еще не работает ... Возвращает $ (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 ]

1 голос
/ 24 апреля 2010

Я думаю, что ваше утверждение if устанавливает атрибут clicked в false. Попробуйте это:

if( $( this ).attr( 'disabled' ) == false ) {
    // do stuff
}
0 голосов
/ 24 апреля 2010

Я думаю, что ваш селектор неверен. Попробуйте это:

$("#fitable > tr td input:enabled:first").focus(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).parents("tbody:first").append(newRow);
});

Вам не нужно проверять отключение в функции-обработчике, потому что это в первую очередь привязывает только к включенным элементам.

0 голосов
/ 24 апреля 2010

Попробуйте это:

$("#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);
            });
        }
    });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...