带有事件监听器的简单 JavaScript 购物清单
这里是超级新手。我需要创建一个杂货清单,将一个项目添加到列表中,删除列表的第一个项目或列表的最后一个项目,并将这些结果显示在底部的数组中。问题是我无法显示添加的项目,因此我无法测试并查看 pop 和 shift 命令是否正常工作。
这就是我现在所拥有的
const groceries = [];
document.getElementById("listAdd").addEventListener("click", listAdd);
document.getElementById("displayList").innerHTML = '';
document.getElementById("deleteFirst").addEventListener("click", deleteFirst);
document.getElementById("deleteLast").addEventListener("click", deleteLast);
//add item to list
function listAdd() {
console.log(groceries.push());
}
//delete first item in list
function deleteFirst() {
console.log(groceries.shift());
}
//delete last item in list
function deleteLast() {
console.log(groceries.pop());
}
//display list
function display() {
for (let i = 0; i < groceries.length; i++) {
let item = groceries[i];
}
}
<h1>Grocery List</h1>
<fieldset>
<legend> Enter your shopping item below</legend>
<span id="listAdd"></span>
<input type="text" id="listAdd" value=><br>
<input type="button" id="listAdd" value="Add to List"><br>
</fieldset>
<fieldset>
<legend>Delete the first item in the array</legend>
<span id="deleteFirst"></span>
<input type="button" id="deleteFirst" value="Delete First Item"><br>
</fieldset>
<fieldset>
<legend> Delete the last item in the array</legend>
<span id="deleteLast"></span>
<input type="button" id="deleteLast" value="Delete Last Item"><br>
</fieldset>
<fieldset>
<span id="displayList"></span>
<legend> Display array</legend>
</fieldset>
Super newbie here. I need to create a grocery list that adds an item to a list, removes the first item of the list, or the last item of the list, and displays these results in an array at the bottom. The problem is that I can't get the added items to display so I can't test and see if the pop and shift commands are working as they should.
Here's what I have at the moment
const groceries = [];
document.getElementById("listAdd").addEventListener("click", listAdd);
document.getElementById("displayList").innerHTML = '';
document.getElementById("deleteFirst").addEventListener("click", deleteFirst);
document.getElementById("deleteLast").addEventListener("click", deleteLast);
//add item to list
function listAdd() {
console.log(groceries.push());
}
//delete first item in list
function deleteFirst() {
console.log(groceries.shift());
}
//delete last item in list
function deleteLast() {
console.log(groceries.pop());
}
//display list
function display() {
for (let i = 0; i < groceries.length; i++) {
let item = groceries[i];
}
}
<h1>Grocery List</h1>
<fieldset>
<legend> Enter your shopping item below</legend>
<span id="listAdd"></span>
<input type="text" id="listAdd" value=><br>
<input type="button" id="listAdd" value="Add to List"><br>
</fieldset>
<fieldset>
<legend>Delete the first item in the array</legend>
<span id="deleteFirst"></span>
<input type="button" id="deleteFirst" value="Delete First Item"><br>
</fieldset>
<fieldset>
<legend> Delete the last item in the array</legend>
<span id="deleteLast"></span>
<input type="button" id="deleteLast" value="Delete Last Item"><br>
</fieldset>
<fieldset>
<span id="displayList"></span>
<legend> Display array</legend>
</fieldset>
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
我认为部分问题可能是您将多个元素 ID 设置为同一事物。例如,你有一个跨度;文本输入;并将按钮输入全部设置为ID:“listAdd”。 ID 是文档树唯一标识 HTML 元素的方式,因此它们必须不同。
作为猜测,您想要的是当您单击相关按钮时运行“listAdd”函数。因此,您可以执行类似的操作...
然后运行代码来添加事件侦听器...
但实际上,我发现编写已附加事件侦听器的 HTML 更简单...
而且您必须更新这些 ID 对于所有事物来说都是唯一的。作为相关说明,表单元素的“name”属性是服务器端代码用来识别传递的值的属性,因此我将更改您的文本输入以具有 name 属性......
我希望这一切都是有用。
编辑...
重新阅读您的帖子以确保我的回复正确并看到安德烈亚斯的快速回复,我将重申他提到的内容:显示功能只是循环浏览您的列表。您需要在 for 循环内添加代码来构建要显示的 HTML,然后设置显示容器元素的 innerHTML 属性。就像...
当我写这篇文章时,我注意到用于编辑杂货数组的辅助方法似乎实际上并未向数组添加任何内容。您需要从表单元素获取您尝试推送的值(例如),然后将其作为参数传递给推送函数......
I think part of the issue might be that you are setting multiple element IDs to the same thing. For example, you have a span; text input; and button input all set to the ID: "listAdd". The ID is how the document tree uniquely identifies the HTML element, so they have to be different.
As a guess, what you want is for the "listAdd" function to run when you click the relevant button. So, you could do something like...
and then run your code to add the event listener...
but really, I find it simpler to just write the HTML with the event listener already attached...
And you would have to update those IDs to be unique for everything. As a related note, the "name" attribute of the form element is what the server side code uses to identify the value that is passed along, so I would change your text inputs to have the name attribute...
I hope all that is useful.
Edit...
Re-reading your post to be sure I was responding correctly and seeing Andreas's quick responses, I'll reiterate what he mentioned: The display function just loops through your list. You need to add code inside the for-loop that builds the HTML you want to display and then set the innerHTML property of your display container element. Something like...
And as I was writing that, I noticed that your helper methods for editing the groceries array doesn't seem to actually add anything to the arrays. You'd need to get the value you're trying to push (for example) from the form element, and then pass that as the parameter to the push function...