javascript - 使用 jquery 删除动态创建的 div

标签 javascript jquery html css

编辑:只是为了下次我问得更好。我得到了 -1 我做错了什么?

我正在动态添加相当多的 html,并且希望能够将它们也一一删除。

在 JQuery 之下。我希望能够通过单击其下方的删除按钮来删除整个 $("#row1' + (counter) + '") div,包括其中的所有 div。

这是一个 fiddle :http://jsfiddle.net/FullContCoder/Sf9r5/1/

提前致谢!

$(document).ready(function() {

    var counter = 0;

    $(".addButton").click(function() {

    var test =    $( '<div id="row1' + (counter) + '" class="row"><div class="col-md-2"><p><small>Placement Name:</small></p><input id="inputPlacement' + (counter) + '" type="text" class="form-control input-sm" name="placementName" placeholder="ex: Homepage">' +
            '</div><div class="col-md-3"><p><small>URL:</small></p><input id="inputURL" type="url" class="form-control input-sm" name="url" placeholder="ex: http://www.allure.com"></div>' +
            '<div class="col-md-2"><div class="row"><div class="col-md-12"><p><small>Select a Date and Time:</small></p></div></div><div class="row"><div class="col-md-12">' +
            '<div class="input-append date" id="dp3" data-date="12-02-2012" data-date-format="dd-mm-yyyy"><input class="span2" size="16" type="text" value="12-02-2012" readonly=""><span class="add-on"><i class="icon-calendar"></i>' +
            '</span></div></div></div><div class="row"><div class="input-append bootstrap-timepicker"><input id="timepicker1" type="text" class="input-small"><span class="add-on">' +
            '<i class="glyphicon glyphicon-time"></i></span></div></div></div><div class="col-md-2"><p><small>Recurring:</small></p><select id="recurring" class="form-control input-sm">' +
            '<option name="daily" value="daily">Daily</option><option name="weekly" value="weekly">Weekly</option><option name="month" value="month">Month</option></select></div>' +
            '<div class="col-md-2"><p><small>Day of Week:</small></p><div class="row"><div class="col-md-6"><label class="checkbox-inline"><input id="mon" name="test" type="checkbox" value="1"> Mon</label>' +
            '</div><div class="col-md-6"><label class="checkbox-inline"><input id="fri" name="test" type="checkbox" value="1"> Fri</label></div></div><div class="row"><div class="col-md-6">' +
            '<label class="checkbox-inline"><input id="tue" name="test" type="checkbox" value="1"> Tue</label></div><div class="col-md-6"><label class="checkbox-inline">' +
            '<input id="sat" name="test" type="checkbox" value="1"> Sat</label></div></div><div class="row"><div class="col-md-6"><label class="checkbox-inline">' +
            '<input id="wen" name="test" type="checkbox" value="1"> Wed</label></div><div class="col-md-6"><label class="checkbox-inline">' +
            '<input id="sun" name="test" type="checkbox" value="1"> Sun</label></div></div><div class="row"><div class="col-md-6"><label class="checkbox-inline">' +
            '<input id="thu" name="test" type="checkbox" value="1"> Thu</label></div></div></div><div class="col-md-1"><p><small>Remove:</small></p>' +
            '<button type="button" class="removeButton btn btn-default btn-sm"><span class="glyphicon glyphicon-minus-sign"></span></button></div></div>' )



        $('.removeButton').click(function() {
            $("#row1' + (counter) + '").remove();
        });

        counter++;


       $("#row1").after(test);
    });




});

最佳答案

你应该使用 event delegation将事件添加到动态创建的元素。并使用 .closest()获取与选择器匹配的第一个元素。试试这个:

$(document).on('click','.removeButton',function() {
     $(this).closest("div.row").remove();
});

您需要将删除按钮 click 处理程序移到添加按钮 click 处理程序之外。

DEMO

关于javascript - 使用 jquery 删除动态创建的 div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23002131/

相关文章:

javascript - 不希望 promise 吞噬错误

javascript - 如何检查谷歌浏览器中用户是否已允许通知?

javascript - PJAX 加载后无法运行脚本

javascript - jquery 删除前置元素不起作用

javascript - 从功能开始或不开始的区别,我需要一些理解

javascript - 应用程序 iOS 中未定义的 Cordova native 存储插件

javascript - 尝试读取元素的文本仅显示第一个元素的文本

html - CSS3 动画只渲染一帧

html - 在内部元素中使用带填充的 Flexbox

javascript - 动画(滑入)新面板以替换当前面板的内容?