typescript 判断单选按钮的选择状态,核心在于获取单选按钮的 checked 属性。这看似简单,实际操作中却有一些细节需要注意,稍有不慎就会掉进坑里。
我曾经在开发一个用户调查问卷系统时,就遇到过这个问题。问卷里有多个单选题,每个单选题下有多个选项,每个选项都是一个单选按钮。当时我直接用 document.querySelector 获取单选按钮,再判断 checked 属性。代码写起来很快,但测试时却发现,只有第一个单选题能正确判断,后面的都失效了。
问题出在 document.querySelector 的选择器上。我最初的代码只使用了单选按钮的 name 属性作为选择器,但多个单选题的选项都使用了相同的 name 属性。document.querySelector 只会返回第一个匹配的元素,导致后面的单选按钮无法正确判断。
解决这个问题的关键在于,给每个单选按钮赋予唯一的标识符。我修改了代码,为每个单选按钮添加了一个唯一的 id 属性,并使用 document.getElementById 获取单选按钮。这样,就能准确地判断每个单选按钮的选择状态了。
下面是一个修正后的例子,假设我们有三个单选题,每个单选题有两个选项:
// HTML 结构示例 (请注意每个单选按钮的唯一id) <div> <input type="radio" id="question1-option1" name="question1" value="option1"> Option 1 <input type="radio" id="question1-option2" name="question1" value="option2"> Option 2 </div> <div> <input type="radio" id="question2-option1" name="question2" value="option1"> Option 1 <input type="radio" id="question2-option2" name="question2" value="option2"> Option 2 </div> <div> <input type="radio" id="question3-option1" name="question3" value="option1"> Option 1 <input type="radio" id="question3-option2" name="question3" value="option2"> Option 2 </div> // TypeScript 代码 function getSelectedValue(questionId: string): string | null { const selectedOption = document.querySelector(`input[name="${questionId}"]:checked`); return selectedOption ? (selectedOption as HTMLInputElement).value : null; } // 获取第一个问题的选择结果 const question1Answer = getSelectedValue("question1"); console.log("Question 1 answer:", question1Answer); // 获取第二个问题的选择结果 const question2Answer = getSelectedValue("question2"); console.log("Question 2 answer:", question2Answer); //依次类推...
登录后复制
这段代码使用了更通用的 querySelector 方法,并通过模板字面量动态生成选择器,避免了之前只使用 name 属性带来的问题。 getSelectedValue 函数返回选中的值,如果没有选中任何选项则返回 null,增强了代码的健壮性。 记住,确保你的 HTML 中每个单选按钮都有一个唯一的 id,这是正确判断的关键。 通过这种方式,你就能可靠地获取 TypeScript 中单选按钮的选择状态了。
路由网(www.lu-you.com)您可以查阅其它相关文章!