添加/删除按钮不适用于重复的表单字段 - jquery

Posted

技术标签:

【中文标题】添加/删除按钮不适用于重复的表单字段 - jquery【英文标题】:Add/Remove button not working on duplicated form fields - jquery 【发布时间】:2013-10-22 10:48:12 【问题描述】:

我已使用以下答案中的代码:jquery clone form fields and increment id 为我的表单创建了一个可克隆区域,除了“添加另一个”和“删除行”按钮外,所有操作都运行良好。

只有原始可克隆区域的添加/删除按钮有效,因此下一个克隆区域的添加/删除按钮不会做任何事情,这意味着您使用了第一行的令人困惑的。

我真的看不出发生了什么。任何帮助将不胜感激!

html

<div id="previous-jobs">
<div class="panel-group" id="accordion">
    <div id="clonedInput1" class="clonedInput panel panel-default">
        <div class="panel-heading clearfix">
            <h4 class="panel-title pull-left">
                <a class="heading-reference accordion-toggle" data-toggle="collapse" data-parent="#accordion" href="#collapse1">
                    Entry #1
                </a>
            </h4>
            <div id="action-buttons" class="pull-right">
                <button type="button" class="btn btn-success clone">Add another</button>
                <button type="button" class="btn btn-danger remove">Delete Row</button>
            </div>
        </div>
        <div id="collapse1" class="input-panel panel-collapse collapse">
            <div class="panel-body">
                <div class="row">
                    <div class="form-group col-sm-6">
                        <label class="p-date-from-title input-title" for="p-date-from">Date From</label>
                        <input type="text" class="ci-df form-control" id="p-date-from1" name="p-date-from" value="[[+!fi.p-date-from]]" placeholder="Date from">
                    </div>
                    <div class="form-group col-sm-6">
                        <label class="p-date-to-title input-title"  for="p-date-to">Date To</label>
                        <input type="text" class="ci-dt form-control" id="p-date-to1" name="p-date-to" value="[[+!fi.p-date-to]]" placeholder="Date to">
                    </div>
                </div>
                <div class="form-group">
                    <label class="p-employer-title input-title"  for="p-employer">Employer</label>
                    <input type="text" class="ci-em form-control" id="p-employer1" name="p-employer" value="[[+!fi.p-employer]]" placeholder="Employer">
                </div>
                <div class="form-group">
                    <label class="p-position-title input-title"  for="p-position">Position</label>
                    <input type="text" class="ci-po form-control" id="p-position1" name="p-position" value="[[+!fi.p-position]]" placeholder="Position">
                </div>
                <div class="form-group">
                    <label class="p-salary-title input-title"  for="p-salary">Salary</label>
                    <input type="text" class="ci-sa form-control" id="p-salary1" name="p-salary" value="[[+!fi.p-salary]]" placeholder="Salary">
                </div>
                <div class="form-group">
                    <label class="p-full-part-time-title input-title"  for="p-full-part-time">Full/Part Time</label>
                    <select class="ci-fpt form-control" id="p-full-part-time1" name="p-full-part-time" value="[[+!fi.p-full-part-time]]">
                        <option value="Full Time">Full Time</option>
                        <option value="Part Time">Part Time</option>
                    </select>
                </div>
                <div class="form-group">
                    <label class="p-leaving-reason-title input-title"  for="p-leaving-reason">Reason for Leaving</label>
                    <input type="text" class="ci-rfl form-control" id="p-leaving-reason1" name="p-leaving-reason" value="[[+!fi.p-leaving-reason]]" placeholder="Reason for leaving">
                </div>
            </div>
        </div>
    </div>
</div>

jQuery:

var regex = /^(.*)(\d)+$/i;
var cloneIndex = $(".clonedInput").length;

$("button.clone").click(function()
cloneIndex++;
$(this).parents(".clonedInput").clone()
    .appendTo("#accordion")
    .attr("id", "clonedInput" +  cloneIndex)
        .find("*").each(function() 
        var id = this.id || "";
        var match = id.match(regex) || [];
        if (match.length == 3) 
                this.id = match[1] + (cloneIndex);
                this.name = match[1] + (cloneIndex);
    
    $(this).find('.heading-reference').attr("href", "#collapse" + cloneIndex).html('Entry #' + cloneIndex);
    );
);

$("button.remove").click(function()
    $(this).parents(".clonedInput").remove();
);

【问题讨论】:

【参考方案1】:

对于动态添加的元素,使用.on() jQuery documentation .on()(对于jQuery 1.7 及更高版本)

在您发布的示例中,他们使用了.live(),它适用于 jQuery 1.7 及以下版本。

将此添加到任何 $(document).ready() 函数之外:

$(document).on('click', 'button.clone', function()
    ...
);

通过这样做,事件处理程序被添加到document,因此任何时候一个源自button.clone 元素的事件冒泡到它,它就会触发该函数。因此,当页面加载后添加按钮时,它们仍然会触发点击事件,即使在页面最初加载时它们不可用。

如果你只使用$('button.clone').click(...),那么只有页面上第一次加载时的按钮才会触发点击事件。

【讨论】:

还要告诉他为什么要使用它。 对不起,我没有早点回复这个问题,我没有收到电子邮件通知!非常感谢!!!这样就解决了。现在我只需要从第一个可克隆区域中删除删除行按钮,这样他们就无法完全删除它。无论哪种方式,这都是一个很大的帮助,非常感谢!

以上是关于添加/删除按钮不适用于重复的表单字段 - jquery的主要内容,如果未能解决你的问题,请参考以下文章

Javascript getElementById() 适用于文本框,但不适用于单选按钮或下拉选择器 [重复]

jquery click函数不适用于每个输入字段

Extjs 无法在表单面板中动态添加/删除字段

jQuery TableSorter 仅适用于 ID(数字字段),不适用于文本、日期等其他字段

用于动态多组条目的组件

JQuery.Dirty 字段不适用于第一个“updateFormState”,但适用于第二个