0

0

如何使用 JavaScript 动态禁用表单中的 radio 按钮

聖光之護

聖光之護

发布时间:2026-01-02 13:30:40

|

287人浏览过

|

来源于php中文网

原创

如何使用 JavaScript 动态禁用表单中的 radio 按钮

本文详解为何 `element.disabled = true` 在动态生成的 radio 元素上失效,并提供完整可运行的解决方案,涵盖 dom 加载时机、字符串解析陷阱、属性设置验证及现代替代写法。

在 ASP.NET Razor 页面中动态控制 radio 按钮的启用/禁用状态时,常见问题并非 JavaScript 语法错误,而是执行时机与数据格式不匹配导致的“看似无效”。你遇到的 sizes[i].disabled = true 不生效,根本原因通常有以下三点:

✅ 1. DOM 尚未就绪(最常见!)

你的 <script> 块直接写在 @foreach 循环内部,且位于所有 <input name="sizes"> 元素<strong>之后——看似合理,但 Razor 渲染顺序 + <a style="color:#f60; text-decoration:underline;" title= "浏览器" href="https://www.php.cn/zt/16180.html" target="_blank">浏览器解析机制可能导致 document.getElementsByName('sizes') 在脚本执行时返回空 NodeList。</script>

✅ 正确做法:将逻辑封装并延迟到 DOM 加载完成

<script>
    // 确保 DOM 完全加载后再初始化事件监听
    document.addEventListener('DOMContentLoaded', function () {
        // 为所有 products radio 绑定 onchange(避免内联 onchange)
        document.querySelectorAll('input[name="products"]').forEach(radio => {
            radio.addEventListener('change', function () {
                displaySizes(this);
            });
        });
    });

    function displaySizes(productSizes) {
        const valueProductSizes = productSizes.value;
        // ⚠️ 关键修复:正确解析 CSV 字符串(注意空格!)
        const availableSizes = valueProductSizes
            .split(',')
            .map(s => s.trim()); // 去除 "one, two, three" 中的空格 → ["one", "two", "three"]

        const sizeRadios = document.querySelectorAll('input[name="sizes"]');

        sizeRadios.forEach(radio => {
            // ✅ 使用 includes() 判断值是否在可用列表中
            if (!availableSizes.includes(radio.value)) {
                radio.disabled = true;
                radio.checked = false; // 防止已选中状态残留
            } else {
                radio.disabled = false; // 重置其他选项(重要!)
            }
        });
    }
</script>

✅ 2. 字符串解析错误(隐藏陷阱)

Razor 中 @string.Join(" ,", product.Sizes) 生成的是 "S ,M ,L",而 value.includes("S") 会误匹配(因 "S " 包含 "S")。includes() 在子串匹配场景下不可靠。

VisualizeAI
VisualizeAI

用AI把你的想法变成现实

下载

立即学习Java免费学习笔记(深入)”;

✅ 推荐改用 Array.includes() + 精确解析:

// ❌ 危险(子串匹配):
// if (!valueProductSizes.includes(sizes[i].value)) 

// ✅ 安全(精确值匹配):
const availableSizes = productSizes.value
    .split(',')
    .map(s => s.trim());
if (!availableSizes.includes(radio.value)) { ... }

✅ 3. 忘记启用之前被禁用的元素

首次调用 displaySizes() 可能禁用部分按钮,但切换到另一个产品时,未启用之前被禁用的按钮,导致状态累积错误。务必在每次调用中先重置所有 radio 的 disabled 状态

sizeRadios.forEach(radio => {
    radio.disabled = !availableSizes.includes(radio.value);
    if (radio.disabled) radio.checked = false;
});

✅ 完整 HTML 结构建议(确保可执行)

<!-- 1. 所有 sizes radio 必须在 script 之前渲染 -->
<div class="productsize">
    <div id="radio-container"></div>
    @foreach (var size in Model.AvailableSizes)
    {
        <input type="radio" name="sizes" id="@size" class="radio-button" value="@size" />
        <label for="@size" class="radio-label">@size</label>
    }
</div>

<!-- 2. products radio(触发器) -->
@foreach (var product in Model.Products)
{
    var sizeCsv = string.Join(",", product.Sizes); // 用英文逗号,无空格
    <input type="radio" 
           name="products" 
           id="@product.Name" 
           class="radio-button" 
           value="@sizeCsv" />
    <label for="@product.Name" class="radio-label">@product.Name</label>
}

<!-- 3. 脚本放在页面底部或 DOMContentLoaded 中 -->
<script>
    // 如上文所示的健壮实现
</script>

? 调试技巧

  • 在控制台执行 document.querySelectorAll('input[name="sizes"]').length 验证元素是否存在;
  • console.log(availableSizes, radio.value, availableSizes.includes(radio.value)) 三连查;
  • 检查浏览器开发者工具 Elements 面板,确认 disabled 属性是否真实写入(而非仅 JS 属性)。
总结:disabled = true 本身永远有效,失效必因 DOM 未就绪、数据解析错误、状态未重置 三者之一。采用 DOMContentLoaded + trim() 解析 + 全量状态管理,即可 100% 解决。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

910

2023.08.02

php中foreach用法
php中foreach用法

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

202

2025.12.04

js 字符串转数组
js 字符串转数组

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

658

2023.08.03

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

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

219

2023.09.04

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

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

1560

2023.10.24

字符串介绍
字符串介绍

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

645

2023.11.24

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

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

1108

2024.03.22

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

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

1062

2024.04.29

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

43

2026.02.28

热门下载

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

精品课程

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

共58课时 | 5.6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.2万人学习

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号