0

0

如何为 ASP.NET Core 中的每个循环项动态绑定唯一删除对话框

花韻仙語

花韻仙語

发布时间:2025-12-29 19:52:03

|

751人浏览过

|

来源于php中文网

原创

如何为 ASP.NET Core 中的每个循环项动态绑定唯一删除对话框

本文介绍在 razor 页面中使用 @foreach 循环渲染多条数据时,如何避免因复用同一

元素导致 asp-route-* 始终传递首个项 id 的问题——核心方案是为每个对话框生成唯一 id,并通过 javascript 动态控制其显隐。

在 ASP.NET Core Razor Pages 中,当在 @foreach 循环内渲染多个删除操作按钮并共用同一个

元素时(如原代码中所有 ),JavaScript 调用 document.getElementById("deleteDialog") 总是返回 DOM 中第一个匹配的元素(即首个循环项对应的 dialog),导致后续点击任意行的“删除”按钮,最终提交的 asp-route-experimentId 始终是第一个 @experiment.Id —— 这并非 JavaScript “重启循环”,而是 ID 冲突引发的 DOM 查询歧义。

✅ 正确做法:为每个对话框分配唯一 ID,并将当前实验 ID 作为参数传入 JS 函数。修改要点如下:

  1. 添加动态 ID(例如 deleteDialog_@experiment.Id);
  2. 标签中传入当前 @experiment.Id 到 showDeleteDialog();
  3. 更新 JS 函数,接收 ID 并精准定位对应 dialog;
  4. 确保

以下是修正后的完整代码示例:

Pliny
Pliny

创建、分享和重新组合AI应用程序

下载
<form method="post">
    <table class="table table-striped">
        <thead>
            <tr>
                <th>Id</th>
                <th>Name</th>
                <th>Actions</th>
            </tr>
        </thead>
        <tbody>
            @foreach (var experiment in Model.MainExperimentsTests)
            {
                <tr>
                    <td>@experiment.Id</td>
                    <td>@experiment.ExperimentTestName</td>
                    <td>
                        <a class="btn btn-sm btn-danger permissionRead permissionWrite"
                           onclick="showDeleteDialog(@experiment.Id)">
                            <i class="bi-bucket"></i> Delete
                        </a>

                        <dialog id="deleteDialog_@experiment.Id">
                            <p>Do you really want to delete experiment <strong>@experiment.ExperimentTestName</strong> (ID: @experiment.Id)?</p>
                            <form method="post">
                                <button type="submit" 
                                        asp-page-handler="Delete" 
                                        asp-route-experimentId="@experiment.Id"
                                        class="btn btn-primary">
                                    Confirm
                                </button>
                                <button type="button" 
                                        onclick="closeDeleteDialog(@experiment.Id)" 
                                        class="btn btn-secondary">
                                    Cancel
                                </button>
                            </form>
                        </dialog>
                    </td>
                </tr>
            }
        </tbody>
    </table>
</form>

<script>
    function showDeleteDialog(experimentId) {
        const dialog = document.getElementById(`deleteDialog_${experimentId}`);
        if (dialog) dialog.showModal();
    }

    function closeDeleteDialog(experimentId) {
        const dialog = document.getElementById(`deleteDialog_${experimentId}`);
        if (dialog) dialog.close();
    }
</script>

⚠️ 注意事项:

  • 必须在循环内部声明,确保每个 experiment 拥有独立的、带唯一 ID 的 dialog 实例;
  • asp-route-experimentId="@experiment.Id" 是服务器端 Razor 渲染的静态属性,无需 JS 动态赋值 —— 它已在 HTML 输出时固化到对应按钮的 form 中;
  • 推荐为
  • 若 experiment.Id 可能含特殊字符(如 -、.),建议在 ID 中做简单转义(如 @experiment.Id.ToString().Replace("-", "_")),但整型 ID 通常无需处理;
  • 现代浏览器对 支持良好(Chrome 37+, Edge 79+, Firefox 98+),生产环境建议添加 dialog-polyfill 兼容旧版。

通过此结构,每个删除操作完全解耦,asp-route-experimentId 将准确传递对应行的数据 ID,彻底解决“总是删第一个”的问题。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
chrome什么意思
chrome什么意思

chrome是浏览器的意思,由Google开发的网络浏览器,它在2008年首次发布,并迅速成为全球最受欢迎的浏览器之一。本专题为大家提供chrome相关的文章、下载、课程内容,供大家免费下载体验。

1046

2023.08.11

chrome无法加载插件怎么办
chrome无法加载插件怎么办

chrome无法加载插件可以通过检查插件是否已正确安装、禁用和启用插件、清除插件缓存、更新浏览器和插件、检查网络连接和尝试在隐身模式下加载插件方法解决。更多关于chrome相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

827

2023.11.06

edge是什么浏览器
edge是什么浏览器

Edge是一款由Microsoft开发的网页浏览器,是Windows 10操作系统中默认的浏览器,其目标是提供更快、更安全、更现代化的浏览器体验。本专题为大家提供edge浏览器相关的文章、下载、课程内容,供大家免费下载体验。

1711

2023.08.21

IE浏览器自动跳转EDGE如何恢复
IE浏览器自动跳转EDGE如何恢复

ie浏览器自动跳转edge的解决办法:1、更改默认浏览器设置;2、阻止edge浏览器的自动跳转;3、更改超链接的默认打开方式;4、禁用“快速网页查看器”;5、卸载edge浏览器;6、检查第三方插件或应用程序等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

396

2024.03.05

如何解决Edge打开但没有标题的问题
如何解决Edge打开但没有标题的问题

若 Microsoft Edge 浏览器打开后无标题(窗口空白或标题栏缺失),可尝试以下方法解决: 重启 Edge:关闭所有窗口,重新启动浏览器。 重置窗口布局:右击任务栏 Edge 图标 → 选择「最大化」或「还原」。 禁用扩展:进入 edge://extensions 临时关闭插件测试。 重置浏览器设置:前往 edge://settings/reset 恢复默认配置。 更新或重装 Edge:检查最新版本,或通过控制面板修复

1031

2025.04.24

php中foreach用法
php中foreach用法

本专题整合了php中foreach用法的相关介绍,阅读专题下面的文章了解更多详细教程。

225

2025.12.04

数据库Delete用法
数据库Delete用法

数据库Delete用法:1、删除单条记录;2、删除多条记录;3、删除所有记录;4、删除特定条件的记录。更多关于数据库Delete的内容,大家可以访问下面的文章。

287

2023.11.13

drop和delete的区别
drop和delete的区别

drop和delete的区别:1、功能与用途;2、操作对象;3、可逆性;4、空间释放;5、执行速度与效率;6、与其他命令的交互;7、影响的持久性;8、语法和执行;9、触发器与约束;10、事务处理。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

222

2023.12.29

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

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

精品课程

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

共58课时 | 5.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

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

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