我正在使用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之上。
答案 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();