- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在构建一个待办事项列表,并向列表中添加一个删除和完成的功能。但是,一旦按下删除/完成按钮,它就会应用于所有 li 元素。此外,如果向列表中添加更多元素,按钮将失去其功能。
我检查了 JS 控制台,没有错误。我构建了一个片段来重现错误:
$(document).ready(function() {
var removeImg = '<img src= "https://www.icon2s.com/wp-content/uploads/2013/07/ios7-trash-icon.png" width = "22px" class = "removeicon">';
var completeImg = '<img src = "https://www.shareicon.net/data/128x128/2016/11/28/857777_circle_512x512.png" class = "completeicon" width = "22px">';
document.getElementById("add").addEventListener('click', function(){
var value = document.getElementById("addtask_TD").value;
var lookat = document.getElementById("addtask_TD");
if (value) {
addItemTodo(value);
lookat.focus();
lookat.select();
}
});
function addItemTodo(text){
var list = document.getElementById('todo');
var item = document.createElement('li');
item.innerText = text;
var buttons = document.createElement('div');
buttons.classList.add('buttons');
var remove = document.createElement('button');
remove.classList.add('remove');
remove.classList.add('btn');
// $(".remove").attr("id","delete");
remove.innerHTML = removeImg;
var complete = document.createElement('button');
complete.classList.add('complete');
complete.classList.add('btn');
// $(".complete").attr("id","done");
complete.innerHTML = completeImg;
buttons.appendChild(remove);
buttons.appendChild(complete);
item.appendChild(buttons);
list.appendChild(item);
document.getElementsByClassName("remove")[0].addEventListener('click', function(){
$(item).fadeOut(1000);
});
document.getElementsByClassName("complete")[0].addEventListener('click', function(){
$(".completeicon").attr("src", "https://png.icons8.com/cotton/50/000000/checkmark.png");
});
}
});
header{
width:100% !important;
height: 80px !important;
position:fixed !important;
top:0 !important;
left:0 !important;
z-index:5 !important;
background: #25b99a !important;
box-shadow:0px 2px 4px rgba(44,62,80,0.15) !important;
padding:15px;
}
#addtask_TD {
width:100% !important;
height:50px !important;
float:left !important;
border-radius: 5px !important;
border: 0px;
box-shadow:none !important;
outline:none;
color:#fff;
font-size:15px;
font-weight:400px;
text-indent:16px;
border-top-right-radius:25px !important;
border-top-left-radius:5px !important;
border-bottom-right-radius:25px !important;
border-bottom-left-radius:5px !important;
text-indent:10px !important;
background-color:rgba(0, 0, 0,0.22) !important;
}
header input:: -webkit-input-placeholder{
color:rgba(255,255,255,.75);
}
header input:: -moz-input-placeholder{
color:rgba(255,255,255,.75);
}
header input:: -o-input-placeholder{
color:rgba(255,255,255,.75);
}
header input:: -ms-input-placeholder{
color:rgba(255,255,255,.75);
}
header button {
width:50px;
height:50px;
position:absolute;
top: 15px;
right:15px;
z-index:2;
border-radius:25px;
background:8px;
box-shadow:none;
outline: none;
background-color:white;
border:none;
-o-appearance:none !important;
-ms-appearance:none !important;
-moz-appearance:none !important;
-webkit-appearance:none !important;
appearance:none !important;
}
header button svg{
width:16px;
height:16px;
position:absolute;
top:50%;
left:50%;
margin: -8px 0 0 -8px;
}
header button svg .fill{
fill: #25b99a;
}
ul.todo{
width:100%;
float:left;
}
.st0{fill:none;}
.st1{fill:#C0CECB;}
ul.todo li {
width:108%;
float:left;
height:50px;
position:relative;
background:darkblue;
border-radius:5px;
box-shadow:0px 1px 2px rgba(44,62,80,0.10);
bottom: -16px;
padding: 0 100px 0 0;
/**margin: -20px;**/
margin: 0 0 15px -20px;
}
.containtodolist{
width:100%;
float:left;
padding: 15px;
}
ul#todo li:last-of-type{
/** margin:0;**/
}
ul#todo li .buttons {
width:100px;
height:50px;
position:absolute;
top:0;
right:0;
}
ul#todo li .buttons button{
width:50px;
height:50px;
float:left;
background:none;
border:0px;
box-shadow:none;
outline:none;
position:relative;
-o-appearance:none !important;
-ms-appearance:none !important;
-moz-appearance:none !important;
-webkit-appearance:none !important;
appearance:none !important;
}
ul#todo li .buttons button:last-of-type:before{
content:'';
width:1px;
height:30px;
position:absolute;
top:10px;
left: 0;
background:#edf0f1;
}
.buttons{
display:block;
}
.noFill{
fill:none;
}
ul#todo li .buttons button svg{
width:22px;
height:22px;
position:absolute;
top:50%;
left:50%;
margin: -11px 0 0 -11px;
}
li{
background-color:lightblue;
margin: 65px 0 -70px 0;
padding-top:7px;
padding-bottom:24px;
padding-left:50px;
border-top: 6px solid #79afaf;
right: 40px;
}
.remove,.complete{
margin: 10px;
}
.remove,.complete{
padding-top: 6px !important;
}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/materialize/0.100.2/css/materialize.min.css">
<script type="text/javascript" src="https://code.jquery.com/jquery-2.1.1.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/materialize/0.100.2/js/materialize.min.js"></script>
<div class = "containtodolist">
<header>
<input id = "addtask_TD" type = "text" placeholder = "Add task">
<button id = "add"><svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"viewBox="0 0 16 16" style="enable-background:new 0 0 16 16;" xml:space="preserve"><g><path class="fill" d="M16,8c0,0.5-0.5,1-1,1H9v6c0,0.5-0.5,1-1,1s-1-0.5-1-1V9H1C0.5,9,0,8.5,0,8s0.5-1,1-1h6V1c0-0.5,0.5-1,1-1s1,0.5,1,1v6h6C15.5,7,16,7.5,16,8z"/></g></svg></button>
</header>
<div class = "container_TD" id = "todo">
<!-- <ul class = "todo" id = "completed">
<li> WHouha
<div class = "buttons">
<button class = "remove"> <img src="https://png.icons8.com/ios/50/000000/delete.png" width = "22px"></button>
<button class = "complete"><img src = "https://www.shareicon.net/data/128x128/2016/11/28/857777_circle_512x512.png" width = "22px"> </button>
</div>
</li>
</ul>-->
</div>
<ul class = "todo" id = "completed"></ul>
</div>
最佳答案
如果你正在使用 jquery,你应该使用 jquery 来选择元素和应用点击事件,不要混用 vanilla js 的 getElementsByClassName
和 addEventListener
。这将使您的代码在未来更难阅读和维护。
问题 1:
once the remove/completed button is pressed, it is applied to the all the li elements
这是因为当你这样做的时候
$(".completeicon").attr("src", "https://png.icons8.com/cotton/50/000000/checkmark.png")
这相当于选择 .completeicon
类的所有元素的 jquery,因此单击一个会触发所有元素。这就是一切都完成的原因。
所有的删除都是出于不同的原因:
document.getElementsByClassName("remove")[0].addEventListener('click', function() {
$(item).fadeOut(1000);
});
每当您添加待办事项时,您只会将删除事件分配给第一个待办事项中的第一个删除按钮(因为它是 document.getElementsByClassName("remove")[0]
)。但是,每次调用 addEventListener
时,item
表示添加到列表中的最新元素。所以点击第一个删除,将连续删除它自己和列表中的其他元素。
这也解释了问题 2:
Furthermore, if one adds more items to the list, the buttons lose their functionality.
那是因为,您只是将事件应用到列表中的第一项([0]
th 项)。
要解决它,您可以直接将事件应用到各种 DOM 元素的变量,而不是使用 document.getElementsByClassName
来选择应用事件的 DOM 元素,这很方便,恕我直言更容易阅读:
就在这之前:
buttons.appendChild(remove);
buttons.appendChild(complete);
item.appendChild(buttons);
list.appendChild(item);
你可以做到
$(remove).click(function(){
$(item).fadeOut(1000);
});
$(complete).click(function(){
$(this).find('.completeicon').attr('src',"https://png.icons8.com/cotton/50/000000/checkmark.png")
});
它只针对最新的 remove
按钮和即将添加的 complete
按钮。然后完全删除 addEventListener
代码。
关于javascript - jQuery 通过 attr 添加 id 不工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49662549/
出现在 python 2.7.8 中。 3.4.1 不会发生这种情况。 示例: >>> id(id) 140117478913736 >>> id(id) 140117478913736 >>> id
好吧,我对动态创建的控件的 ID 很困惑。 Public Class TestClass Inherits Panel Implements INamingContainer
我收到下面的错误,说有堆栈溢出。发生这种情况是因为带有 IN (id, id, id...id) 的 SQL 语句有大量参数。有没有什么办法解决这一问题?这是在我使用 Eclipse 的本地环境中发生
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
为什么 CPython(对其他 Python 实现一无所知)有以下行为? tuple1 = () tuple2 = ()
非常简单的问题:当我有一个持久对象时,它通常有一个名为 ID 的属性(对于抽象类)。 那么..命名约定是ID还是Id? 例如。 public int ID { get; set; } 或 public
知道为什么我会收到此错误,我已经尝试了所有命名约定(小写/大写) 我正在使用 Vaadin,这是我的代码片段: public class Usercontainer extends BeanI
为什么 CPython(不知道其他 Python 实现)有以下行为? tuple1 = () tuple2 = ()
我需要改变表的所有主键 UPDATE TODO SET id = id + 1 但我做不到(Demo 来自 Ahmad Al-Mutawa 的回答)描述了原因。主键不能这样改。 我也不能根据这是 sq
我正在尝试列出与用户相关的讨论列表。 想象一下,如果你愿意的话: posts -------------------------------------------------------------
我有一个表,其中包含一些具有自己的 ID 和共享 SKU key 的文章。我尝试使用左连接进行查询,并使用组结果获取从查询返回的所有 id。 我的数据结构是这样的: id - name -
在下表People中: id name 1 James 2 Yun 3 Ethan 如果我想找到最大 ID,我可以运行此查询 select max(id) id from People; 结果是
我正在产品页面上创建评论模块,其中显示垃圾评论选项,并显示 onclick 显示和隐藏弹出窗口。现在它在单个评论中工作正常但是当评论是两个时它同时打开两个因为类是相同的。现在这就是为什么我想要获取父
根据 REST 哲学,PUT操作应该(取自维基百科): PUT http://example.com/resources/142 Update the address member of the co
我想知道如何在使用 PHP 或 JavaScript 进行身份验证后从 Google Analytics 获取 Property Id、View Id 和 Account Id?因为我希望能够将它们存
我想使用所选按钮的 ID 进行删除。但我不知道如何从中获取/获取 id。我尝试了 this.id 但不起作用。 这是我创建按钮的地方: var deleteEmployer= document.cre
我有一个具有以下结构的表“表” ID LinkedWith 12 13 13 12 14 13 15 14 16
请不要在未阅读问题的情况下将问题标记为重复。我确实发布了一个类似的问题,但 STACKOVERFLOW 社区成员要求我单独重新发布修改后的问题,因为考虑到一个小而微妙的修改,解决方案要复杂得多。 假设
在 Android Studio 中,我创建了一个 Person.java 类。我使用Generate 创建了getter 和setter 以及构造函数。 这是我的 Person.java 类: pu
如何在 jQuery 中制作这样的东西: //这是显示的主体 ID //当我悬停 #hover-id 时,我希望 #principal-id 消失并更改 。但是当我将光标放在 #this-id 上时
我是一名优秀的程序员,十分优秀!