Изменить цвет фона на радио выбрать - PullRequest
0 голосов
/ 04 октября 2009

У меня есть следующий код

 <form id="form1" name="form1" method="post">
     <table width="100%" border="0" cellspacing="0" cellpadding="0">

  <tr>
      <td ><div class="label_main" id="lab1">
        <div class="label_radio">
          <input type="radio" name="group1" id="r0" value="0" />
        </div>
        <div class="label_top">
          <label for="r0">Group1</label>
        </div>
        <div class="label_desc">
          <label for="r1">Members of Groups1 </label>
        </div>
      </div>
          </div>    </tr>
    <tr>
      <td><div class="label_main">
        <div class="label_radio">
          <input type="radio" name="group1" id="r1" value="1" />
        </div>
        <div class="label_top">
          <label for="r1">Groups2</label>
        </div>
        <div class="label_desc">
          <label for="r1">Only Group 2 </label>
        </div>
      </div></td>
    </tr>
</table>
</form>



.label_main_selected
    {
    padding-top:0px;
    float:left;
    background:#E9ECFF;
    }

То, что я хочу, это:

Как только я выбираю любую радио-кнопку, фон основного DIV изменяется как (label_main_selected) class

Спасибо

Ответы [ 3 ]

1 голос
/ 04 октября 2009

Долгий путь:

$('input:radio').click(function() {
    if($(this).is(':checked')) {

        //select the main div wrapping this radio
        $(this).parent().parent().addClass('.label_main_selected');

        //or you can do
        //$(this).closest('.label_main').addClass('.label_main_selected');
    } else {
        $(this).parent().parent().removeClass('.label_main_selected');
        //or $(this).closest('.label_main').removeClass('.label_main_selected');
    }
});

Короткий путь (может или не может подойти для этой цели, зависит от точно того, что вы ищете):

$('input:radio').click(function() {
    $(this).parent().parent().toggleClass('.label_main_selected');
    //or $(this).closest('.label_main').toggleClass('.label_main_selected');
});

См:

0 голосов
/ 20 октября 2018
$('input:radio').click(function() {
    var selected = $(this).val();
    $(".checkboxtable").find("tr").each(function() {
        var idx = $(this).data("id");
        if(idx == selected){
            $("#dspackage-"+idx).addClass("bg");    
        }else{
            $("#dspackage-"+idx).removeClass("bg");    
        }
    });
});
0 голосов
/ 02 декабря 2017

$(document).ready(function(){
    $("input:radio").click(function(){
       if ($(this).is(":checked")){
       $("label").css({"color":"green","background-color":"#6600cc"}) && $(this).closest("label").css({"color":"green","background-color":"orange"});
       }
    });
});
input[type=radio],
     input[type=checkbox] {
       display: none;
     }
label {
color:white;
font-size:48px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>


<form>
  <label for="Male">
    <input type="radio" class="button" id="Male" name="gender">Male
  </label>
  <label for="Female">
    <input type="radio" class="button" id="Female" name="gender">Female
   </label>
</form>
...