CSS - show div when selecting checkbox

I am trying to show a div when one of the selected in the group is checked and hidden when not. I thought this should work, but it does not work.

https://jsfiddle.net/47ctm349/2/

#form-group-osobko {
  display: none;
}

#odber-1:checked+#form-group-osobko {
  display: block;
}
<!-- Multiple Checkboxes -->
<div class="form-group">
  <label class="col-md-4 control-label" for="odber">Způsob platby</label>
  <div class="col-md-4">
    <div class="checkbox">
      <label for="odber-0">
        <input type="checkbox" name="odber" id="odber-0" value="1"> Dobírka
      </label>
    </div>
    <div class="checkbox">
      <label for="odber-1">
        <input type="checkbox" name="odber" id="odber-1" value="2"> Hotově při osobním odběru
      </label>
    </div>
    <div class="checkbox">
      <label for="odber-2">
        <input type="checkbox" name="odber" id="odber-2" value="3"> Platba předem na účet
      </label>
    </div>
  </div>
</div>

<!-- Text input-->
<div class="form-group" id="form-group-osobko">
  <label class="col-md-4 control-label" for="osobniodber">Místo osobního odběru</label>
  <div class="col-md-4">
    <input id="osobniodber" name="osobniodber" type="text" placeholder="14900,11000" class="form-control input-md">
    <span class="help-block">Zadejte PSČ míst možného osobního odběru oddělená čárkou.</span>
  </div>
</div>
Run code

It should work, when you click the checkbox in the middle, a div should appear id="form-group-osobko".

I tried not to use JS with my bootstrap.

I can not understand what I'm doing wrong :(

Thank.

+4
source share
2 answers

Your solution only works if the displayed div is an adjacent cathedral of flag input, as this +selector in CSS means.

div , , CSS JavaScript.

#form-group-osobko {
  display: none;
}
#odber-1:checked+#form-group-osobko {
  display: block;
}
<!-- Multiple Checkboxes -->
<div class="form-group">
  <label class="col-md-4 control-label" for="odber">Způsob platby</label>
  <div class="col-md-4">
    <div class="checkbox">
      <label for="odber-0">
        <input type="checkbox" name="odber" id="odber-0" value="1">Dobírka
      </label>
    </div>
    <div class="checkbox">
      <label for="odber-1">
        <input type="checkbox" name="odber" id="odber-1" value="2">Hotově při osobním odběru

        <!-- Text input-->
        <div class="form-group" id="form-group-osobko">
          <label class="col-md-4 control-label" for="osobniodber">Místo osobního odběru</label>
          <div class="col-md-4">
            <input id="osobniodber" name="osobniodber" type="text" placeholder="14900,11000" class="form-control input-md">
            <span class="help-block">Zadejte PSČ míst možného osobního odběru oddělená čárkou.</span>
          </div>
        </div>

      </label>
    </div>
    <div class="checkbox">
      <label for="odber-2">
        <input type="checkbox" name="odber" id="odber-2" value="3">Platba předem na účet
      </label>
    </div>
  </div>
</div>

jQuery, div:

$('#odber-1').change(function(){
  $('#form-group-osobko').toggleClass("active");
});
#form-group-osobko {
  display: none;
}
#form-group-osobko.active {
  display: block;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<!-- Multiple Checkboxes -->
<div class="form-group">
  <label class="col-md-4 control-label" for="odber">Způsob platby</label>
  <div class="col-md-4">
    <div class="checkbox">
      <label for="odber-0">
        <input type="checkbox" name="odber" id="odber-0" value="1">Dobírka
      </label>
    </div>
    <div class="checkbox">
      <label for="odber-1">
        <input type="checkbox" name="odber" id="odber-1" value="2">Hotově při osobním odběru
      </label>
    </div>
    <div class="checkbox">
      <label for="odber-2">
        <input type="checkbox" name="odber" id="odber-2" value="3">Platba předem na účet
      </label>
    </div>
  </div>
</div>

<!-- Text input-->
<div class="form-group" id="form-group-osobko">
  <label class="col-md-4 control-label" for="osobniodber">Místo osobního odběru</label>
  <div class="col-md-4">
    <input id="osobniodber" name="osobniodber" type="text" placeholder="14900,11000" class="form-control input-md">
    <span class="help-block">Zadejte PSČ míst možného osobního odběru oddělená čárkou.</span>
  </div>
</div>
+5

https://jsfiddle.net/47ctm349/5/

Javascript, JQuery. div :

$('#odber-0').on('change', function(){
if($('#odber-0').is(':checked'))
        $("#form-group-osobko").css("display","block");
else
$("#form-group-osobko").css("display","none");
});

$('#odber-1').on('change', function(){
if($('#odber-1').is(':checked'))
        $("#form-group-osobko").css("display","block");
else
$("#form-group-osobko").css("display","none");
});

$('#odber-2').on('change', function(){
if($('#odber-2').is(':checked'))
        $("#form-group-osobko").css("display","block");
else
$("#form-group-osobko").css("display","none");
});

CSS. !

0

Source: https://habr.com/ru/post/1656800/


All Articles