gpt4 book ai didi

javascript - 带按钮的模态添加新行(每次单击一行)

转载 作者:行者123 更新时间:2023-11-28 02:15:52 25 4
gpt4 key购买 nike

我对标题中的模态有疑问。当我单击标题“安全”时,它会打开安全模式,并且每次单击都设法添加一行,这很棒。当我复制第二个标题的代码时,即“操作”。问题开始了。在我打开 Safety 的模态、添加新元素并关闭模态后,我打开 Operate 的模态并添加新元素。我添加的新元素不是每次点击一行,它每次点击添加两行,有时每次点击添加三行。

请帮忙。

// Get the  that opens the Safety NewsFeed
var s_news = document.getElementById('s_news');
var safety = document.getElementById('Safety');
safety.onclick = function() {
s_news.style.display = "block";
$('.AddNew').click(function() {
var row = $(this).closest('tr').clone();
row.find('input').val('');
$(this).closest('tr').after(row);
$('input[type="button"]', row).removeClass('AddNew').addClass('RemoveRow').val('Remove item');
});

$('table').on('click', '.RemoveRow', function() {
$(this).closest('tr').remove();
});
}

// Get the <span> element that closes the modal
var snews_span = document.getElementsByClassName("s_newsclose")[0];
// When the user clicks on <span> (x), close the modal
snews_span.onclick = function() {
s_news.style.display = "none";
}
// Close Safety NewsFeed
window.addEventListener("click", function(s_newsevent) {
if (s_newsevent.target == s_news) {
s_news.style.display = "none";
}
});
///
// Get the that opens the Quality Internal NewsFeed
var qi_news = document.getElementById('qi_news');
var qualityint = document.getElementById('QualityInt');
qualityint.onclick = function() {
qi_news.style.display = "block";
$('.AddNew').click(function() {
var row = $(this).closest('tr').clone();
row.find('input').val('');
$(this).closest('tr').after(row);
$('input[type="button"]', row).removeClass('AddNew').addClass('RemoveRow').val('Remove item');
});

$('table').on('click', '.RemoveRow', function() {
$(this).closest('tr').remove();
});
}

// Get the <span> element that closes the modal
var qinews_span = document.getElementsByClassName("qi_newsclose")[0];
// When the user clicks on <span> (x), close the modal
qinews_span.onclick = function() {
qi_news.style.display = "none";
}
// Close Safety NewsFeed
window.addEventListener("click", function(qi_newsevent) {
if (qi_newsevent.target == qi_news) {
qi_news.style.display = "none";
}
});
/* News Feed (background) */

.s_news,
.qi_news {
display: none;
/* Hidden by default */
position: fixed;
/* Stay in place */
z-index: 1;
/* Sit on top */
left: 0;
top: 0;
width: 100%;
/* Full width */
height: 100%;
/* Full height */
background-color: rgb(0, 0, 0);
/* Fallback color */
background-color: rgba(0, 0, 0, 0.9);
/* Black w/ opacity */
}

.headercolor {
background-color: rgba(255, 0, 0, 1);
}


/* The Newsfeed Close Button */

.s_newsclose,
.qi_newsclose {
color: #aaa;
float: left;
font-size: 28px;
font-weight: bold;
}
<html>

<body>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>

<h2 style="font-size:1.5rem" id=Safety>Safety</h2>
<h2 style="font-size:1.5rem" id=QualityInt>Operate</h2>

<div id="s_news" class="s_news">
<table>
<tr>
<td class=headercolor>ISSUE</td>
<td class=headercolor>ACTION</td>
<td class=headercolor>Add/Remove Item</td>
</tr> <span class="s_newsclose">&times;</span>
<tr>
<td><input type='text' value='Add New'></td>
<td><input type='text' value='Add New'></td>
<td><input type='button' class='AddNew' value='Add new item'></td>
</tr>
</table>
</div>

<div id="qi_news" class="qi_news">
<table>
<tr>
<td class=headercolor>ISSUE</td>
<td class=headercolor>ACTION</td>
<td class=headercolor>Add/Remove Item</td>
</tr> <span class="qi_newsclose">&times;</span>
<tr>
<td><input type='text' value='Add New'></td>
<td><input type='text' value='Add New -->'></td>
<td><input type='button' class='AddNew' value='Add new item'></td>
</tr>
</table>

</div>

</body>

</html>

最佳答案

检查嵌套在 safety.onclick 代码块中的代码。 每次单击“安全”时,您都将 jQuery click() 事件处理程序绑定(bind)到所有具有 AddNew 类属性的元素.您可以在您提供的代码片段中亲眼看到这一点。单击标题,然后立即将其关闭。再重复两次。现在,当您单击“添加元素”按钮时,您会看到显示 新行。

另外,请注意您想要实现的效果对于每个 div 是如何相同的。我会推荐更多 DRY在此处处理您的代码。考虑一个替代解决方案,其中您的 jQuery 事件绑定(bind)使用 .on() 方法并且不嵌套在普通 onclick 处理程序中。

$('#s_news, #qi_news').on('click', '.AddNew', function() {
var row = $(this).closest('tr').clone();
row.find('input').val('');
$(this).closest('tr').after(row);
$('input[type="button"]', row)
.removeClass('AddNew')
.addClass('RemoveRow')
.val('Remove item');
});

$('#s_news, #qi_news').on('click', '.RemoveRow', function() {
$(this).closest('tr').remove();
});

下面是实现添加/删除事件处理代码的示例:https://jsfiddle.net/v5r2f913

对所提供的代码示例再作一点一般性评论:由于您使用的是 jQuery,因此您可以考虑仅使用该库的选择器和事件模型,而不是混合使用 jQuery 和原生 JavaScript。

关于javascript - 带按钮的模态添加新行(每次单击一行),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48482385/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com