繁体   English   中英

如何获取所选单选按钮的值?

[英]How to get the selected radio button’s value?

我的 JS 程序有一些奇怪的问题。 我让这个工作正常,但由于某种原因它不再工作。 我只想找到单选按钮的值(选择了哪个)并将其返回给变量。 由于某种原因,它不断返回undefined

这是我的代码:

function findSelection(field) {
    var test = 'document.theForm.' + field;
    var sizes = test;

    alert(sizes);
        for (i=0; i < sizes.length; i++) {
            if (sizes[i].checked==true) {
            alert(sizes[i].value + ' you got a value');     
            return sizes[i].value;
        }
    }
}

submitForm

function submitForm() {

    var genderS =  findSelection("genderS");
    alert(genderS);
}

HTML:

<form action="#n" name="theForm">

    <label for="gender">Gender: </label>
    <input type="radio" name="genderS" value="1" checked> Male
    <input type="radio" name="genderS" value="0" > Female<br><br>
    <a href="javascript: submitForm()">Search</A>
</form>

这适用于任何资源管理器。

document.querySelector('input[name="genderS"]:checked').value;

这是获取任何输入类型的值的简单方法。 也不需要包含 jQuery 路径。

你可以这样做:

 var radios = document.getElementsByName('genderS'); for (var i = 0, length = radios.length; i < length; i++) { if (radios[i].checked) { // do whatever you want with the checked radio alert(radios[i].value); // only one radio can be logically checked, don't check the rest break; } }
 <label for="gender">Gender: </label> <input type="radio" name="genderS" value="1" checked="checked">Male</input> <input type="radio" name="genderS" value="0">Female</input>

提琴手

编辑:感谢 HATCHA 和 jpsetung 的编辑建议。

document.forms.your-form-name.elements.radio-button-name.value

从 jQuery 1.8 开始,查询的正确语法是

$('input[name="genderS"]:checked').val();

不是$('input[@name="genderS"]:checked').val(); 不再,它在 jQuery 1.7 中工作(使用@ )。

ECMAScript 6 版本

let genderS = Array.from(document.getElementsByName("genderS")).find(r => r.checked).value;

最简单的解决方案:

 document.querySelector('input[name=genderS]:checked').value

如果有人正在寻找答案并像我一样来到这里,从 Chrome 34 和 Firefox 33 开始,您可以执行以下操作:

var form = document.theForm;
var radios = form.elements['genderS'];
alert(radios.value);

或者更简单:

alert(document.theForm.genderS.value);

参考: https : //developer.mozilla.org/en-US/docs/Web/API/RadioNodeList/value

这是使用纯 JavaScript 获取选中单选按钮值的好方法:

const form = document.forms.demo;
const checked = form.querySelector('input[name=characters]:checked');

// log out the value from the :checked radio
console.log(checked.value);

来源: https : //ultimatecourses.com/blog/get-value-checked-radio-buttons

使用这个 HTML:

<form name="demo">
  <label>
    Mario
    <input type="radio" value="mario" name="characters" checked>
  </label>
  <label>
    Luigi
    <input type="radio" value="luigi" name="characters">
  </label>
  <label>
    Toad
    <input type="radio" value="toad" name="characters">
  </label>
</form>

您还可以使用Array Find the checked属性来查找选中的项目:

Array.from(form.elements.characters).find(radio => radio.checked);

尝试这个

function findSelection(field) {
    var test = document.getElementsByName(field);
    var sizes = test.length;
    alert(sizes);
    for (i=0; i < sizes; i++) {
            if (test[i].checked==true) {
            alert(test[i].value + ' you got a value');     
            return test[i].value;
        }
    }
}


function submitForm() {

    var genderS =  findSelection("genderS");
    alert(genderS);
    return false;
}

这里有一个小提琴。

这是纯 JavaScript,基于@Fontas 的回答,但如果没有选定的单选按钮,则使用安全代码返回空字符串(并避免TypeError ):

var genderSRadio = document.querySelector("input[name=genderS]:checked");
var genderSValue = genderSRadio ? genderSRadio.value : "";

代码分解如下:

  • 第 1 行:获取对 (a) 是<input>类型的控件的引用,(b) 具有name属性genderS ,并且 (c) 已检查。
  • 第 2 行:如果有这样的控件,则返回其值。 如果没有,则返回一个空字符串。 如果第 1 行找到控件,则性别genderSRadio变量为真,否则为 null/falsey。

对于 JQuery,请使用 @jbabey 的答案,并注意如果没有选定的单选按钮,它将返回undefined

编辑:正如 Chips_100 所说,你应该使用:

var sizes = document.theForm[field];

直接不使用测试变量。


旧答案:

你不应该eval这样呢?

var sizes = eval(test);

我不知道它是如何工作的,但对我来说你只是在复制一个字符串。

首先,对ashraf aaref 大喊大叫,我想稍微扩展一下他的回答。

正如 MDN Web Docs 所建议的,使用RadioNodeList是首选方式:

// Get the form
const form = document.forms[0];

// Get the form's radio buttons
const radios = form.elements['color'];

// You can also easily get the selected value
console.log(radios.value);

// Set the "red" option as the value, i.e. select it
radios.value = 'red';

然而,也可以通过querySelector选择表单,这也可以正常工作:

const form = document.querySelector('form[name="somename"]')

然而,直接选择电台将无法正常工作,因为它返回一个简单的NodeList

document.querySelectorAll('input[name="color"]')
// Returns: NodeList [ input, input ]

选择表单时首先返回一个RadioNodeList

document.forms[0].elements['color']
// document.forms[0].color # Shortcut variant
// document.forms[0].elements['complex[naming]'] # Note: shortcuts do not work well with complex field names, thus `elements` for a more programmatic aproach
// Returns: RadioNodeList { 0: input, 1: input, value: "red", length: 2 }

这就是为什么你必须先选择表单,然后调用elements方法。 除了所有input节点之外, RadioNodeList还包括一个属性value ,它可以实现这种简单的操作。

参考: https : //developer.mozilla.org/en-US/docs/Web/API/RadioNodeList/value

这是一个没有使用Checked="checked"属性的 Radios 示例

function test() {
var radios = document.getElementsByName("radiotest");
var found = 1;
for (var i = 0; i < radios.length; i++) {       
    if (radios[i].checked) {
        alert(radios[i].value);
        found = 0;
        break;
    }
}
   if(found == 1)
   {
     alert("Please Select Radio");
   }    
}

演示http : //jsfiddle.net/ipsjolly/hgdWp/2/ [点击查找而不选择任何收音机]

来源(来自我的博客): http : //bloggerplugnplay.blogspot.in/2013/01/validateget-checked-radio-value-in.html

Ed Gibbs的答案放入一般的 function 中:

function findSelection(rad_name) {
    const rad_val = document.querySelector('input[name=' + rad_name + ']:checked');
    return (rad_val ? rad_val.value : "");
}

然后你可以做findSelection("genderS");

让我们假设您需要在表单中放置不同行的单选按钮,每个单选按钮具有单独的属性名称('option1'、'option2' 等)但具有相同的类名称。 也许您需要它们在多行中,每行都将根据与问题相关的 1 到 5 的比例提交一个值。 你可以像这样写你的javascript:

<script type="text/javascript">

    var ratings = document.getElementsByClassName('ratings'); // we access all our radio buttons elements by class name     
    var radios="";

    var i;
    for(i=0;i<ratings.length;i++){
        ratings[i].onclick=function(){
            var result = 0;
            radios = document.querySelectorAll("input[class=ratings]:checked");
            for(j=0;j<radios.length;j++){
                result =  result + + radios[j].value;
            }
            console.log(result);
            document.getElementById('overall-average-rating').innerHTML = result; // this row displays your total rating
        }
    }
</script>

我还将最终输出插入到一个隐藏的表单元素中,以便与表单一起提交。

使用纯 javascript,您可以处理对调度事件的对象的引用。

function (event) {
    console.log(event.target.value);
}
 document.querySelector('input[name=genderS]:checked').value

如果您可以为表单 element() 分配 Id,则可以将这种方式视为一种安全的替代方式(特别是当无线电组元素名称在文档中不唯一时):

function findSelection(field) {
    var formInputElements = document.getElementById("yourFormId").getElementsByTagName("input");
    alert(formInputElements);
        for (i=0; i < formInputElements.length; i++) {
        if ((formInputElements[i].type == "radio") && (formInputElements[i].name == field) && (formInputElements[i].checked)) {
            alert(formInputElements[i].value + ' you got a value');     
            return formInputElements[i].value;
        }
    }
}

HTML:

<form action="#n" name="theForm" id="yourFormId">

我喜欢使用括号从输入中获取值,它比使用点更清晰。

document.forms['form_name']['input_name'].value;

我更喜欢使用formdata 对象,因为它表示提交表单时应该发送的值。

演示

 let formData = new FormData(document.querySelector("form")); console.log(`The value is: ${formData.get("choice")}`);
 <form> <p>Pizza crust:</p> <p> <input type="radio" name="choice" value="regular" > <label for="choice1id">Regular crust</label> </p> <p> <input type="radio" name="choice" value="deep" checked > <label for="choice2id">Deep dish</label> </p> </form>

 <input type=radio name=rdbExampleInfo id=rdbExamples value="select 1">
 <input type=radio name=rdbExampleInfo id=rdbExamples value="select 2">
 <input type=radio name=rdbExampleInfo id=rdbExamples value="select 3">
 <input type=radio name=rdbExampleInfo id=rdbExamples value="select 4"> 

等然后使用

  $("#rdbExamples:checked").val()

或者

   $('input[name="rdbExampleInfo"]:checked').val();
    var value = $('input:radio[name="radiogroupname"]:checked').val();

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM