- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在使用 jQuery,它不想删除我拥有的输入元素。脚本的其余部分运行良好,它似乎忽略了我给它的 .remove() 命令。
所以基本上我有一些 div (在 foreach 语句中复制),其中我有一个 documentTitle 类,其中内部是文档标题的打印值。单击时,它会丢失 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.');
}
}
});
});
在顶部附近的第二个脚本 block 中,您可以在底部附近看到 .remove。
对于 HTML,在实际单击 div 之前,这是单个“文档”的样子:
<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 之上。
最佳答案
问题是您将 this
元素替换为另一个元素,因此 $(this).siblings(".controlTitle")
不会t 返回任何元素(this
不再具有类 controlTitle
的同级元素)。
要修复此问题,您可以在替换 span
之前删除 input
:
$(this).siblings(".controlTitle").remove();
$(this).replaceWith(viewableText);
或者更改查找输入
的方式
$(this).replaceWith(viewableText);
viewableText.siblings(".controlTitle").remove();
关于javascript - .remove() 在 jQuery 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49055230/
我正在使用 .remove() 方法删除一个 html 元素,同时对于这个元素,我有一个事件处理程序,但它没有被触发。为什么会这样呢?这是jsFiddle和代码:HTML Delete I'm goi
所以我尝试从另一篇文章中编写此代码: while(fscanf(orderFile," %49[^;];%d; %49[^\n]",fileName,&seconds,timeValue) == 3)
我正在阅读 Nicolai M.Josuttis 撰写的“The C++ STL. A Tutorial and References”一书,在专门介绍 STL 算法的一章中,作者陈述如下:如果你调用
是否有一种简单的机制来确定 DownloadManager remove() 何时完成,因为它看起来是部分异步的。该函数几乎立即返回下载表中已删除的条目计数,但实际的文件系统管理似乎被插入了某个后台线
我愿意: getActionBarToolbar().removeView(logoImage); getActionBarToolbar().addView(logoImage, lp); 我得到:
我有类(class)评论一对多关系。在类(class)表中有 id 和 title 列。在 Review 表中,有 id、comment 和 course_id,其中“course_id”作为指向类(
我在 stackoverflow 上阅读了不同的答案,了解如何销毁 wigdet/jQueryObject 并取消绑定(bind)其上的所有事件。 这就是我的想法。 $('选择器').remove()
我有一个由一个线程填充的 byte[] 列表,然后我有另一个线程正在从该列表中读取并通过网络发送项目。 每次我读取线程 2 中的项目时,我都想将其从内存中清除。但是因为我正在使用线程,如果我使用 .r
就算法而言,从连续数组中删除一组元素可以分两部分有效地完成。 将所有不删除的元素移到数组的前面。 将数组标记得更小。 这可以在 C++ 中使用 erase-remove 习惯用法来完成。 vector
我尝试删除包含在 map 中渲染的制造商的 View 。当我单击按钮时,事件 click .ver 被激活,但没有任何反应,并且我收到以下错误:Uncaught TypeError: undefine
场景: 使用 jQuery 2.0.1 构建的应用程序。 您的团队更喜欢原生 JavaScript。 选项有jQuery .remove()和 ChildNode.remove() . 您需要删除节点
最初我有一个像这样的删除功能: function ViewWorkflowDetail(btn, workflowId) { $("#workflowDetailPanel").remov
我正在编写 C++ 代码来解决 Leetcode 中的这个问题:https://leetcode.com/problems/remove-element/ Given an array nums an
根据太阳, "Iterator.remove is the only safe way to modify a collection during iteration; the behavior is
众所周知,从 std::vector 中完全删除所需项的一种好方法是 erase-remove idiom . 如以上链接中所述(截至本文发布日期),在代码中,erase-remove 习惯用法如下所
我在 HashSet 上调用 Iterator.remove() 时遇到问题。 我有一组带有时间戳的对象。在将新项目添加到集合之前,我会遍历集合,识别该数据对象的旧版本并将其删除(在添加新对象之前)。
这段代码: Collection col = new ArrayList(); col.add("a"); col.add("b"); col.add("c");
我试图通过在下面输入来卸载 conda 环境基础, conda env remove -n base 正如我所建议的那样,我尝试通过使用来停用基地 conda deactivate base 我再次尝
我已经对我的 IOS 应用程序进行了质量扫描分析。我收到以下警告: The binary has Runpath Search Path (@rpath) set. In certain cases
这个问题已经有答案了: Properly removing an Integer from a List (8 个回答) 已关闭 4 年前。 我是java新手。看起来很简单,但我不明白为什么会发生这种
我是一名优秀的程序员,十分优秀!