.remove()不能在jQuery中工作

时间:2018-03-01 17:14:13

标签: javascript jquery

我正在使用jQuery并且它不想删除我拥有的输入元素。其余的脚本运行正常,它似乎忽略了我给它的.remove()命令。

所以基本上我有一些div(在foreach语句中复制),在其中我有一个documentTitle类,其中inside是文档标题的打印值。单击时,它会丢失div并将div的值放在输入字段中,这是该部分的特定脚本:

function divClicked() {
    var divHtml = $(this).html();
    var editableText = $("<input class='form-control controlTitle' name='title'>");
    editableText.val(divHtml);
    $(this).closest(".documentTitleHover").addClass('editing');
    $(this).siblings( ".fa-check" ).removeClass('hidden');
    $(this).replaceWith(editableText);
    editableText.focus();
}

现在我的问题出现了当点击右上角部分的一个小标记,发生了很多事情,并且它们完美无缺地工作(包括ajax部分)时会发生什么,但唯一拒绝工作的是.remove();

这是特定的脚本:

$("span.fa.fa-check").click(function () {
  var checkMarkSpan = $(this);
  var parentDocumentDiv = checkMarkSpan.closest("div.document");

    var html = $(this).siblings( "input[name='title']" ).val();
    var viewableText = $("<div class='documentTitle'>");
    $(this).closest(".documentTitleHover").removeClass('editing');
    $(this).siblings( ".fa-check" ).addClass('hidden');
    viewableText.html(html);
    $(this).replaceWith(viewableText);
    $(this).siblings(".controlTitle").remove();
    // setup the click event for this new div
    viewableText.click(divClicked);

  // now do the Ajax. Notice how the inputs are searched below the div, not everywhere ($)
  $.ajax({
            type:'POST',
            url: '/carrier/claims/files/updateFile',
            data: {
                'attachmentID': parentDocumentDiv.find('input[name=attachmentID]').val(),
                'title': parentDocumentDiv.find('input[name=title]').val(),
               '_token': parentDocumentDiv.find('input[name=_token]').val(),
            },
            success: function(data) {
                    $('.errorTitle').addClass('hidden');
                    $('.errorContent').addClass('hidden');

                    if ((data.errors)) {
                        setTimeout(function () {
                            $('#createOrigin').modal('show');
                            toastr.error('Check your inputs!', 'Error Alert', {timeOut: 5000});
                        }, 500);

                        if (data.errors.title) {
                            $('.errorTitle').removeClass('hidden');
                            $('.errorTitle').text(data.errors.title);
                        }
                        if (data.errors.content) {
                            $('.errorContent').removeClass('hidden');
                            $('.errorContent').text(data.errors.content);
                        }
                    } else {
                        toastr.success('Changed Title Successfully To '+data.claim.title, 'Success Alert', {timeOut: 5000});
                       $('#existing_consignee_details').html(
'<strong>'+data.customer_name+'</strong><br>'+data.billing_address_1 +' '+data.billing_address_2 +'<br>'+data.billing_city +', '+data.billing_state + ' '+data.billing_zipcode+'<br><br><a href="/customers/i/'+data.id+'" target="_blank"><button type="button" class="btn btn-primary btn-sm">View Customer Details</button></a>' );

                    }
                },

                error: function (jqXHR, textStatus, errorThrown) {
                  if (jqXHR.status == 500) {
                      alert('Internal error: ' + jqXHR.responseText);
                  } else {
                      alert('Unexpected error.');
                  }
                }
            });
});

在顶部附近,在第二个脚本块中,您会看到靠近底部的.remove。

对于HTML,在实际点击div之前,这就是个人&#34;文档&#34;看起来像:

<div class="documentTitleHover">
                                <div class="documentTitle">Document 14</div>
                                    <span class="fa fa-edit"></span>
                                    <span class="fa fa-check hidden"></span>
                            </div>

这就是点击div后的样子:

<div class="documentTitleHover editing">
                                <input class="form-control controlTitle" name="title">
                                    <span class="fa fa-edit"></span>
                                    <span class="fa fa-check"></span>
                            </div>

这就是点击复选标记后的样子:

<div class="documentTitleHover">
                                <input class="form-control controlTitle" name="title">
                                    <span class="fa fa-edit"></span>
                                    <div class="documentTitle">Document 15</div>
                            </div>

从我的脚本中可以看出,当单击复选标记时,输入应该被删除,但它会保留在新创建的div之上。

1 个答案:

答案 0 :(得分:1)

问题是你要用另一个元素替换this元素,因此$(this).siblings(".controlTitle")不会返回任何元素(this不再有类的兄弟controlTitle)。

要解决此问题,您可以在替换input之前移除span

$(this).siblings(".controlTitle").remove();
$(this).replaceWith(viewableText);

或者更改找到input

的方式
$(this).replaceWith(viewableText);
viewableText.siblings(".controlTitle").remove();