新闻中心
如何在点击时删除列表中特定项而非最后一项

本文档旨在帮助开发者解决在J*aScript中,点击列表项时总是删除最后一项的问题。我们将通过修改事件处理方式,准确获取被点击元素的索引,并从数组中删除对应项,从而实现点击删除特定列表项的功能。本文提供了详细的代码示例和步骤说明,助你轻松掌握该技巧。
在动态生成列表并希望实现点击删除特定项的功能时,开发者常常会遇到点击任何列表项都只删除最后一项的问题。这通常是由于事件处理方式不正确,导致无法准确获取被点击元素的索引。以下提供一种解决方案,帮助你正确实现点击删除特定列表项的功能。
核心思路:
- 修改HTML结构: 将删除按钮添加到每个列表项内部,并为每个按钮绑定点击事件。
- 修改事件处理函数: 在事件处理函数中,通过event.target获取被点击的元素,进而获取该元素对应的列表项的索引。
- 使用splice()方法: 使用splice()方法从数组中删除指定索引的元素。
- 重新渲染列表: 删除元素后,重新渲染列表,以反映最新的数据。
详细步骤和代码示例:
1. 修改HTML结构
将删除按钮(或者其他触发删除操作的元素)添加到每个列表项
<ul id="itemList"> </ul>
在 J*aScript 中动态生成列表项时,将删除按钮添加到每个
2. 修改 J*aScript 代码
万相营造
阿里妈妈推出的AI电商营销工具
168
查看详情
首先,修改 arrayList 函数,使其能够为每个列表项添加点击事件和删除按钮。
let myArray = ["Sugar", "Milk", "Bread", "Apples"];
let list1 = document.querySelector("#itemList");
//This function pushed my array items to create the list
arrayList = (arr) => {
list1.innerHTML = ''; // Clear the list before re-rendering
arr.forEach(item => {
let li = document.createElement('li');
li.textContent = item;
li.onclick = deleteItem; // Attach the deleteItem function to the li element
list1.appendChild(li);
});
}
arrayList(myArray)然后,修改 deleteItem 函数,使其能够获取被点击元素的索引,并从数组中删除对应项。
//This function is meant to delete the specified item chosen by the user from the shopping list and the array
deleteItem = (event) => {
let clk = event.target.innerHTML;
//console.log(clk);
let index = myArray.indexOf(clk);
if (index > -1) {
myArray.splice(index, 1);
}
arrayList(myArray) // Re-render the list
}3. 完整代码示例:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Shopping List</title>
<!-- Link Google Font -->
<link href="https://fonts.googleapis.com/css2?family=Nunito&display=swap" rel="stylesheet">
<!-- External CSS link-->
<link rel="stylesheet" href="./css/styles.css">
</head>
<body>
<div class="container">
<h2>Shopping List</h2>
<div class="header">
<input type="text" id="input" placeholder="Item">
<span onclick="updateList(myArray)" id="addBtn"><button>Add Item</button></span>
</div>
<span value="\uOOD7" class="close">
<ul id="itemList">
</ul>
</span>
</div>
<script>
//This is a j*ascript program which added the items in my array to an unordered list
let myArray = ["Sugar", "Milk", "Bread", "Apples"];
let list1 = document.querySelector("#itemList");
//This function pushed my array items to create the list
arrayList = (arr) => {
list1.innerHTML = ''; // Clear the list before re-rendering
arr.forEach(item => {
let li = document.createElement('li');
li.textContent = item;
li.onclick = deleteItem; // Attach the deleteItem function to the li element
list1.appendChild(li);
});
}
arrayList(myArray)
//This function changed the background color of two of the list items to show that they are sold
const idSelector = () => {
let idElement = document.getElementsByTagName("li")
idElement[0].style.color = "red"
idElement[3].style.color = "red"
}
idSelector()
//This function uses the user input from the form to add items to the list
updateList = (arr) => {
let blue = document.getElementById("input").value;
if (blue === "") {
alert("Please enter a value if you wish to add something to your list.")
} else {
arr.push(blue);
list1.innerHTML = '';
arrayList(myArray)
idSelector()
}
}
//This function is meant to delete the specified item chosen by the user from the shopping list and the array
deleteItem = (event) => {
let clk = event.target.innerHTML;
//console.log(clk);
let index = myArray.indexOf(clk);
if (index > -1) {
myArray.splice(index, 1);
}
arrayList(myArray) // Re-render the list
}
</script>
</body>
</html>注意事项:
- event.target: event.target 属性返回触发事件的元素。在本例中,它返回被点击的
- 元素。
- indexOf(): indexOf() 方法返回在数组中可以找到给定元素的第一个索引,如果不存在,则返回 -1。
- splice(): splice() 方法通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容。 arr.splice(index, 1) 表示从索引 index 处删除 1 个元素。
- 数据同步: 确保数组 myArray 和列表 itemList 中的数据始终保持同步。每次修改数组后,都要重新渲染列表。
总结:
通过修改HTML结构和J*aScript代码,可以实现点击删除列表中特定项的功能。 关键在于正确获取被点击元素的索引,并使用 splice() 方法从数组中删除对应项。同时,要注意数据同步,确保数组和列表中的数据一致。希望本教程能够帮助你解决相关问题。
以上就是如何在点击时删除列表中特定项而非最后一项的详细内容,更多请关注其它相关文章!
# 自定义
# 耐克网站的网络推广
# 德宏420seo-80310
# 江苏网站建设方案书
# 梅州哪有网站建设
# seo排名工具拣选火星10
# 济南外贸seo推广招聘
# 上海网站建设网站设计
# 巩义seo优化课程招商加盟
# 宾馆在什么网站推广
# 西湖区seo优化服务
# 拖拽
# 并从
# 如何在
# 绑定
# 使其
# css
# 而非
# 列表中
# 复选框
# 组中
# red
# 点击事件
# google
# apple
# ai
# app
# go
# html
# java
# javascript
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
使用Python高效删除Word宏并转换DOCM为DOCX格式
写好的html代码怎么运行出来_运行写好的html代码方法【教程】
AO3同人作品网入口 AO3搜索引擎官网永久地址
外媒分析《GTA6》定价:卖100美元可以但真没必要!
在哪找SublimeJ远程工具_SFTP插件配置教程
sublime怎么预览Markdown渲染效果_Markdown Preview插件 for sublime教程
React中useState与局部变量:理解组件状态管理与渲染机制
夸克AO3官网入口_AO3镜像网站2025推荐
Composer的 "conflict" 字段有什么用_如何声明不兼容的包以避免依赖冲突
飞书妙记怎样用语音转文字速记_飞书妙记用语音转文字速记【速记方法】
J*a中实现Go语言select通道多路复用机制
C++如何操作大型数据集_使用C++流式处理(Streaming)技术避免一次性加载大文件
如何更改在 Excel 中打开超链接时的默认浏览器
文心一言怎样用插件调度API数据_文心一言用插件调度API数据【API调用】
win11专注助手在哪 Win11免打扰模式设置与自动化规则【指南】
c++如何使用折叠表达式(Fold Expressions)_c++17可变参数模板新技巧
微信网页版官方入口教程 微信网页版网页版快速登录步骤
mc.js游戏直达 mc.js网页免下载版本秒进地址
理解Python模块与全局变量的作用域管理
Vue.js 图片显示异常排查:理解应用挂载范围与DOM ID唯一性
如何在Python中使用Optional类型处理可变对象并避免Pylint警告
电脑IP地址怎么查 查看本机IP地址的几种方法
C++ string find函数返回值npos详解_C++字符串查找失败的判断条件
《噬血代码2》新预告片发布 展示游戏剧情
mcjs网页版流畅运行 mcjs低配电脑畅玩入口
mc.js免安装版 mc.js一键畅玩入口
微信群消息显示延迟如何解决 微信群消息刷新优化方法
修复二维数组索引越界异常:一维循环到二维坐标的正确映射
怎样在Excel中做仪表盘_Excel仪表盘设计与关键指标展示方法
Lar*el 递归关系中排除指定分支的教程
12306怎么选座位选到安静区_12306选座安静区域选择策略
Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】
百度网盘网页版入口 百度网盘网页版官方登录网址
sublime怎么覆盖插件的默认快捷键_sublime快捷键优先级与设置
b站怎么删除评论_b站评论管理与删除操作
QQ网页版官方账号入口 QQ网页版网页版登录指南
J*aScript DOM操作:高效清空列表元素的策略与实践
响应式图片在网页设计中的正确实现方法
Win11怎么开启卓越性能模式 Win11电源选项启用高性能释放硬件潜力【方法】
解决Python logging 中 datefmt 导致时间戳固定不变的问题
Python多版本共存与虚拟环境管理深度指南
Lar*el 8 多关键词数据库搜索优化实践
Django表单提交验证失败后保持字段值不刷新
Linux如何构建多环境配置管理_Linux多环境配置方案
马斯克:Optimus 人形机器人复数形式为 Optimi
ArrayList与LinkedList核心操作的Big-O复杂度分析
深入理解Google Cloud Datastore查询:祖先路径与数据一致性
b站怎么看视频的弹幕数量_b站弹幕数量查看方法
AO3最新官网入口公告_2025AO3镜像站实时查询方法
快手官方唯一登录入口 谨防山寨钓鱼网站


2025-10-29
浏览次数:次
返回列表
</div>
<span value="\uOOD7" class="close">
<ul id="itemList">
</ul>
</span>
</div>
<script>
//This is a j*ascript program which added the items in my array to an unordered list
let myArray = ["Sugar", "Milk", "Bread", "Apples"];
let list1 = document.querySelector("#itemList");
//This function pushed my array items to create the list
arrayList = (arr) => {
list1.innerHTML = ''; // Clear the list before re-rendering
arr.forEach(item => {
let li = document.createElement('li');
li.textContent = item;
li.onclick = deleteItem; // Attach the deleteItem function to the li element
list1.appendChild(li);
});
}
arrayList(myArray)
//This function changed the background color of two of the list items to show that they are sold
const idSelector = () => {
let idElement = document.getElementsByTagName("li")
idElement[0].style.color = "red"
idElement[3].style.color = "red"
}
idSelector()
//This function uses the user input from the form to add items to the list
updateList = (arr) => {
let blue = document.getElementById("input").value;
if (blue === "") {
alert("Please enter a value if you wish to add something to your list.")
} else {
arr.push(blue);
list1.innerHTML = '';
arrayList(myArray)
idSelector()
}
}
//This function is meant to delete the specified item chosen by the user from the shopping list and the array
deleteItem = (event) => {
let clk = event.target.innerHTML;
//console.log(clk);
let index = myArray.indexOf(clk);
if (index > -1) {
myArray.splice(index, 1);
}
arrayList(myArray) // Re-render the list
}
</script>
</body>
</html>