0

0

如何动态添加与移除复选框选中项到列表中

花韻仙語

花韻仙語

发布时间:2026-01-31 08:56:19

|

602人浏览过

|

来源于php中文网

原创

如何动态添加与移除复选框选中项到列表中

本文介绍如何在用户勾选/取消勾选复选框时,精准地向列表中添加或仅删除对应项,避免误清空整个列表;核心在于为每项生成唯一 id 并通过 dom 操作实现局部增删。

在构建多选审批人、成员选择器等交互场景时,一个常见需求是:当用户勾选某个复选框(如员工姓名),其信息立即以卡片形式显示在“已选列表”中;而当用户取消勾选时,仅移除该项对应的内容,而非清空整个列表。原始代码的问题在于:else 分支中使用了 document.getElementById('listUser').innerHTML = "",导致每次取消勾选都重置整个容器内容。

✅ 正确实现思路

  1. 为每个复选框绑定唯一标识(推荐使用递增 ID 或用户 ID,而非 name 值,避免重复风险);
  2. 动态生成带唯一 id 的 HTML 片段(如 zuojiankuohaophpcnol id="user-1">...),确保可精准定位;
  3. 勾选时追加(+=)HTML,取消勾选时调用 .remove() 删除对应 DOM 节点
  4. 避免内联 onclick 中混用 PHP 与 JS 变量,推荐将数据通过 data-* 属性传递,提升可维护性。

✅ 优化后的完整示例

{{-- Blade 模板:渲染复选框列表 --}}
@foreach($users as $index => $user)
    <ol class="list-group">
        <div class="card">
            <li class="list-group-item group-containers">
                <div class="row">
                    <input 
                        type="checkbox" 
                        class="form-check-input" 
                        data-user-id="{{ $user->id }}" 
                        data-user-name="{{ $user->name }}" 
                        data-user-email="{{ $user->email }}"
                        onclick="toggleApprover(this)"
                    >
                    <div class="col-1 c-avatar mr-3">
                        <img class="c-avatar-img" src="{{ url('/assets/img/avatars/3.png') }}">
                    </div>
                    <div class="col-8">
                        <div>{{ $user->name }}</div>
                        <label class="text-secondary">{{ $user->email }}</label>
                    </div>
                </div>
            </li>
        </div>
    </ol>
@endforeach

{{-- 已选列表容器 --}}
<div id="listUser"></div>
// JavaScript:安全、可扩展的增删逻辑
function toggleApprover(cb) {
    const userId = cb.dataset.userId;
    const userName = cb.dataset.userName;
    const userEmail = cb.dataset.userEmail;
    const container = document.getElementById('listUser');
    const itemId = `approver-${userId}`;

    if (cb.checked) {
        // 构建唯一 ID 的 HTML 片段
        const itemHtml = `
            <ol id="${itemId}" class="list-group">
                <div class="card">
                    <li class="list-group-item">
                        <div class="row">
                            <div class="col-1 c-avatar mr-3">
                                <img class="c-avatar-img" src="{{ url('/assets/img/avatars/3.png') }}">
                            </div>
                            <div class="col-8">
                                <div>${userName}</div>
                                <label class="text-secondary">${userEmail}</label>
                            </div>
                        </div>
                    </li>
                </div>
            </ol>`;
        container.insertAdjacentHTML('beforeend', itemHtml);
    } else {
        // 精准移除对应节点(即使不存在也不报错)
        const targetItem = document.getElementById(itemId);
        if (targetItem) targetItem.remove();
    }
}

⚠️ 注意事项与最佳实践

  • ID 唯一性至关重要:切勿对多个元素使用相同 id="approver",这会破坏 DOM 查询逻辑;应使用 data-* 存储业务数据,id 仅用于 DOM 定位。
  • 避免直接操作 innerHTML 追加:虽可行,但频繁拼接字符串易引发 XSS 风险(尤其含用户输入时)。更安全的方式是创建元素后 appendChild,或使用模板引擎。
  • 服务端校验不可省略前端增删仅为体验优化,最终提交时仍需服务端验证所选用户是否合法、是否存在越权。
  • 考虑无障碍支持:为复选框添加 aria-label 或关联 <label>,提升可访问性。

通过以上改造,即可实现「勾选即显、取消即隐」的精准交互,大幅提升表单可用性与代码健壮性。

Wave.Video
Wave.Video

一个在线的AI自动化视频创作平台

下载

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

781

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1571

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

652

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1269

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1226

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

196

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

151

2025.08.07

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

7

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 13.8万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.4万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号