Как показать или скрыть div внутри контейнера на основе выбора флажка

#jquery

#jquery

Вопрос:

Я пытаюсь показать значения, основанные на проверке и снятии флажка

Например, если установлен флажок Показывать всю математику, я хочу отобразить всю панель пакетов, для которой выбрана математика

Аналогично, если установлен флажок Показать всю физику, я хочу отобразить всю панель пакетов, для которой выбран Physiscs

Я пробовал это так

 $(document).on('change', '.filtermaths', function() {
 $(".pack-panel").each(function () {
    var visible = $(this).find('.mathscheckbox').prop('checked')
   $(this).toggle(visible);
  });
  });


$(document).on('change', '.filterphysics', function() {
 $(".pack-panel").each(function () {
    var visible = $(this).find('.physicscheckbox').prop('checked')
   $(this).toggle(visible);
  });
  });

  $(document).on('change', '.filterchemistry', function() {
 $(".pack-panel").each(function () {
    var visible = $(this).find('.chemistrycheckbox').prop('checked')
   $(this).toggle(visible);
  });
  });
  

Но это работает не так, как ожидалось

Это моя скрипка

http://jsfiddle.net/cod7ceho/135/

Не могли бы вы сообщить мне, как это исправить

Ответ №1:

Вы могли бы попробовать что-то вроде этого.

 $(document).on("change", ".actions", function(event) {
  if ($("input[name='includeAll']:checked").val() === "OR") {
    if ($("input:checked", $(".actions")).length === 0) {
      $(".pack-panel").addClass("visible").removeClass("hidden");
    } else {
      $(".pack-panel").addClass("hidden");
    }

    $("input:checked", $(".actions")).each(function() {
      var $target = $(this);
      var isChecked = $target.prop("checked");
      var value = $target.data("course-flag");

      if (isChecked) {
        $("."   value   "-checkbox:checked").closest(".pack-panel").addClass("visible").removeClass("hidden");
      }
    });
  } else {

    var selectedCourses = [];

    $("input:checked", $(".actions")).each(function() {
      selectedCourses.push($(this).data("course-flag"));
    });

    selectAll(selectedCourses);
  }


});

function selectAll(courses) {

  $(".pack-panel").each(function() {
    var $panel = $(this);
    var allSelected = true;
    courses.forEach(function(course) {

      if ($panel.find("."   course   "-checkbox:checked").length === 0) {
        allSelected = false;
      }
    });

    if (allSelected) {
      $panel.addClass("visible").removeClass("hidden");
    } else {
      $panel.removeClass("visible").addClass("hidden");
    }
  });
}  
 .visible {
  display: block;
}
.hidden {
  display: none;
}  
 <link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<label>

  <input type="radio" value="AND" name="includeAll" checked/>AND
</label>
<label>
  <input type="radio" value="OR" name="includeAll" />OR
</label>
<div class="row">
  <div class="col-lg-9 actions">
    <label class="mt-checkbox mt-checkbox-outline">
      <input class="filtermaths" data-course-flag="maths" type="checkbox">Show All Maths<span></span>
    </label>
    <label class="mt-checkbox mt-checkbox-outline">
      <input class="filterphysics" type="checkbox" data-course-flag="physics">Show All Physics<span></span>
    </label>
    <label class="mt-checkbox mt-checkbox-outline">
      <input class="filterchemistry" type="checkbox" data-course-flag="chemistry">Show All Chemistry<span></span>
    </label>
  </div>
  <hr>


  <div class="sortable col-lg-12" id="pacstable">
    <div class="portlet portlet-sortable light bordered pack-panel">
      <div class="portlet-title">
        <div class="row">
          <div class="col-md-7">
            <div class="packdtsl">
              <div class="packimg"></div>
              <ul>
                <li>
                  <span class="title pac_inner">Student Name:</span>
                  <span>
                           <h1 class="studentname">Mark</h1>
                        </span>
                </li>
              </ul>
            </div>
          </div>
          <div class="col-md-2">
            <div class="packrow">

            </div>
          </div>
          <div class="col-md-3">
            <div class="packrow">
              <ul>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="maths-checkbox" value="maths" type="checkbox" checked="">Maths<span></span>
                  </label>
                </li>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="physics-checkbox" value="physics" type="checkbox" checked="">Physics<span></span>
                  </label>
                </li>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="chemistry-checkbox" value="chemistry" type="checkbox" checked="">Chemistry<span></span>
                  </label>
                </li>
              </ul>
            </div>
          </div>
        </div>
      </div>
    </div>
    <div class="portlet portlet-sortable light bordered pack-panel">
      <div class="portlet-title">
        <div class="row">
          <div class="col-md-7">
            <div class="packdtsl">
              <div class="packimg"></div>
              <ul>
                <li>
                  <span class="title pac_inner">Student Name:</span>
                  <span>
                           <h1 class="studentname">Micheal</h1>
                        </span>
                </li>
              </ul>
            </div>
          </div>
          <div class="col-md-2">
            <div class="packrow">
            </div>
          </div>
          <div class="col-md-3">
            <div class="packrow">
              <ul>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="maths-checkbox" value="maths" type="checkbox" checked="">Maths<span></span>
                  </label>
                </li>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="physics-checkbox" value="physics" type="checkbox" checked="">Physics<span></span>
                  </label>
                </li>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="chemistry-checkbox" value="chemistry" type="checkbox" unchecked="">Chemistry<span></span>
                  </label>
                </li>
              </ul>
            </div>
          </div>
        </div>
      </div>
    </div>

    <div class="portlet portlet-sortable light bordered pack-panel">
      <div class="portlet-title">
        <div class="row">
          <div class="col-md-7">
            <div class="packdtsl">
              <div class="packimg"></div>
              <ul>
                <li>
                  <span class="title pac_inner">Student Name:</span>
                  <span>
                           <h1 class="studentname">Roger</h1>
                        </span>
                </li>
              </ul>
            </div>
          </div>
          <div class="col-md-2">
            <div class="packrow">
            </div>
          </div>
          <div class="col-md-3">
            <div class="packrow">
              <ul>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="maths-checkbox" value="maths" type="checkbox" checked="">Maths<span></span>
                  </label>
                </li>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="physics-checkbox" value="physics" type="checkbox" unchecked="">Physics<span></span>
                  </label>
                </li>
                <li>
                  <label class="mt-checkbox mt-checkbox-outline">
                    <input class="chemistry-checkbox" value="chemistry" type="checkbox" unchecked="">Chemistry<span></span>
                  </label>
                </li>
              </ul>
            </div>
          </div>
        </div>
      </div>
    </div>
  </div>
</div>  

Я немного изменил разметку, чтобы перейти от выбора флажков вверху к тем, что находятся внутри панелей пакета.

Изменил код, чтобы учесть оба условия ИЛИ и И. Это должно решить вашу проблему.

Комментарии:

1. Спасибо, но это не работает, например, если вы выберете Показать всю математику и показать всю физику, будут показаны неправильные данные.

2. Является ли это условием ИЛИ или и, когда выбрана вся физика и вся математика, должно ли оно возвращать, где выбраны оба или выбраны какие-либо из математики и физики?

3. извините за поздний ответ, все является только условием И

4. пожалуйста, посмотрите эту скрипку jsfiddle.net/cod7ceho/184 это не работает

5. Похоже, есть какая-то проблема с jsfiddle.. Тот же фрагмент кода работает, как и ожидалось, в фрагменте кода Stackoverflow и CodePen: codepen.io/jsreekanth/pen/QKkZbJ amp; jsbin также: jsbin.com/zojihaziqu/edit?html ,js

Ответ №2:

попробуйте этот самый короткий код

 $('.actions input').on('change', function () {
    if ($('.actions input:checked').length <= 0)
        $(".pack-panel").show();
    else {
        $(".pack-panel").show();
        $('.actions input:checked').each(function () {
            var cclass = $(this).attr('class').split('filter')[1]   "checkbox";                    
            $('.'   cclass).each(function () {                            
                if(!$(this).prop('checked')){
                    $(this).parents('.pack-panel').hide();
                }
            });
        });
    }
});
  

Комментарии:

1. Большое спасибо, пожалуйста, посмотрите эту скрипку jsfiddle.net/cod7ceho/183 когда я проверяю Показать всю математику и показать всю физику, он также отображает вторую строку (под которой физика не выбрана

2. Его a и условие . (НЕ ИЛИ)

Ответ №3:

 var fields = ['maths', 'physics', 'chemistry'];
var visible = {};

$('.actions input').on('change', function(){
    var atLeastOne = false;
    for(var field of fields){
        visible[field] = false;
        if($('.filter'   field).prop('checked')){
            visible[field] = true;
            atLeastOne = true;
        }
    }

    if(!atLeastOne){
        $(".pack-panel").show();
    }else{
        $(".pack-panel").hide();
        for(var field of fields){
            if(!visible[field]){ continue; }
            $(".pack-panel").each(function () {
                if($(this).is(':visible')) { return; }
                if($(this).find('.' field 'checkbox').prop('checked')){
                    $(this).show();
                    return;
                }
            });
        }
    }
});