新闻中心

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

2025-10-29
浏览次数:
返回列表

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

本文档旨在帮助开发者解决在J*aScript中,点击列表项时总是删除最后一项的问题。我们将通过修改事件处理方式,准确获取被点击元素的索引,并从数组中删除对应项,从而实现点击删除特定列表项的功能。本文提供了详细的代码示例和步骤说明,助你轻松掌握该技巧。

在动态生成列表并希望实现点击删除特定项的功能时,开发者常常会遇到点击任何列表项都只删除最后一项的问题。这通常是由于事件处理方式不正确,导致无法准确获取被点击元素的索引。以下提供一种解决方案,帮助你正确实现点击删除特定列表项的功能。

核心思路:

  1. 修改HTML结构: 将删除按钮添加到每个列表项内部,并为每个按钮绑定点击事件。
  2. 修改事件处理函数: 在事件处理函数中,通过event.target获取被点击的元素,进而获取该元素对应的列表项的索引。
  3. 使用splice()方法: 使用splice()方法从数组中删除指定索引的元素。
  4. 重新渲染列表: 删除元素后,重新渲染列表,以反映最新的数据。

详细步骤和代码示例:

1. 修改HTML结构

将删除按钮(或者其他触发删除操作的元素)添加到每个列表项

  • 内部。并且,将 onclick 事件直接绑定到每个
  • 元素上,并传入 event 对象。
    <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镜像站实时查询方法  快手官方唯一登录入口 谨防山寨钓鱼网站 

    搜索