jQuery $(“#radioButton”)。更改(...)在取消选择期间不会触发

时间:2011-03-03 04:52:35

标签: javascript jquery html radio-button

大约一个月前,米特的问题没有得到答复。可悲的是,我现在遇到了同样的情况。

http://api.jquery.com/change/#comment-133939395

以下是这种情况:我正在使用jQuery来捕获单选按钮中的更改。选中单选按钮后,启用编辑框。取消选中单选按钮后,我希望禁用编辑框。

启用工作。当我在组中选择其他单选按钮时,change事件被触发。有谁知道如何解决这个问题?

<input type="radio" id="r1" name="someRadioGroup"/> 

<script type="text/javascript">
    $("#r1").change(function () {
        if ($("#r1").attr("checked")) {
            $('#r1edit:input').removeAttr('disabled');
        }
        else {
            $('#r1edit:input').attr('disabled', true);
        }
    });
</script>

9 个答案:

答案 0 :(得分:308)

看起来change()功能仅在您选中单选按钮时调用,而不是在取消选中时调用。我使用的解决方案是将change事件绑定到每个单选按钮:

$("#r1, #r2, #r3").change(function () {

或者您可以为所有单选按钮指定相同的名称:

$("input[name=someRadioGroup]:radio").change(function () {

这是一个有效的jsfiddle example(根据Chris Porter的评论更新。)

Per @ Ray的评论,你应该避免在其中使用.的名字。这些名称适用于jQuery 1.7.2,但不适用于其他版本(jsfiddle example.)。

答案 1 :(得分:34)

<input id='r1' type='radio' class='rg' name="asdf"/>
<input id='r2' type='radio' class='rg' name="asdf"/>
<input id='r3' type='radio' class='rg' name="asdf"/>
<input id='r4' type='radio' class='rg' name="asdf"/><br/>
<input type='text' id='r1edit'/>                  

jquery part

$(".rg").change(function () {

if ($("#r1").attr("checked")) {
            $('#r1edit:input').removeAttr('disabled');
        }
        else {
            $('#r1edit:input').attr('disabled', 'disabled');
        }
                    });

这是DEMO

答案 2 :(得分:22)

您可以通过名称一次绑定到所有单选按钮:

$('input[name=someRadioGroup]:radio').change(...);

这里的工作示例: http://jsfiddle.net/Ey4fa/

答案 3 :(得分:5)

这通常对我有用:

if ($("#r1").is(":checked")) {}

答案 4 :(得分:3)

我的问题很相似,这对我有用:

$('body').on('change', '.radioClassNameHere', function() { ...

答案 5 :(得分:0)

我们假设这些单选按钮位于div内,其ID为radioButtons且单选按钮具有相同的名称(例如commonName),然后:< / p>

$('#radioButtons').on('change', 'input[name=commonName]:radio', function (e) {
    console.log('You have changed the selected radio button!');
});

答案 6 :(得分:0)

使用Ajax,对我来说工作:

HTML:

<div id='anID'>
 <form name="nameOfForm">
            <p><b>Your headline</b></p>
            <input type='radio' name='nameOfRadio' value='seed' 
             <?php if ($interviewStage == 'seed') {echo" checked ";}?> 
            onchange='funcInterviewStage()'><label>Your label</label><br>
 </form>
</div>

使用Javascript:

 function funcInterviewStage() {

                var dis = document.nameOfForm.nameOfRadio.value;

                //Auswahltafel anzeigen
                  if (dis == "") {
                      document.getElementById("anID").innerHTML = "";
                      return;
                  } else { 
                      if (window.XMLHttpRequest) {
                          // code for IE7+, Firefox, Chrome, Opera, Safari
                          xmlhttp = new XMLHttpRequest();
                      } else {
                          // code for IE6, IE5
                          xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");
                      }
                      xmlhttp.onreadystatechange = function() {
                          if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
                              document.getElementById("anID").innerHTML = xmlhttp.responseText;
                          }
                      }
                      xmlhttp.open("GET","/includes/[name].php?id="+dis,true);
                      xmlhttp.send();
                  }
              }  

和php:

//// Get Value
$id = mysqli_real_escape_string($db, $_GET['id']);

//// Insert to database
$insert = mysqli_query($db, "UPDATE [TABLE] SET [column] = '$id' WHERE [...]");

//// Show radio buttons again
$mysqliAbfrage = mysqli_query($db, "SELECT [column] FROM [Table] WHERE [...]");
                  while ($row = mysqli_fetch_object($mysqliAbfrage)) {
                    ...
                  }
                  echo" 
                  <form name='nameOfForm'>
                      <p><b>Your headline</b></p>
                      <input type='radio' name='nameOfRadio' value='seed'"; if ($interviewStage == 'seed') {echo" checked ";} echo" onchange='funcInterviewStage()'><label>Yourr Label</label><br>
                      <input type='radio' name='nameOfRadio' value='startup'"; if ($interviewStage == 'startup') {echo" checked ";} echo" onchange='funcInterviewStage()'><label>Your label</label><br>

                  </form> ";

答案 7 :(得分:0)

取消选择时未触发的change事件是所需的行为。您应该在整个无线电组上运行一个选择器,而不仅仅是单个单选按钮。您的广播组应具有相同的名称(具有不同的值)

请考虑以下代码:

$('input[name="job[video_need]"]').on('change', function () {
    var value;
    if ($(this).val() == 'none') {
        value = 'hide';
    } else {
        value = 'show';
    }
    $('#video-script-collapse').collapse(value);
});

我有与你相同的用例,即在选择特定的单选按钮时显示输入框。如果事件在取消选择时被触发,我每次都会得到2个事件。

答案 8 :(得分:0)

这里的问题相同,这很好用:

$('input[name="someRadioGroup"]').change(function() {
    $('#r1edit:input').prop('disabled', !$("#r1").is(':checked'));
});