繁体   English   中英

根据下拉选择隐藏/显示内容

[英]Hide/Show Content Based On Dropdown Selection

如何根据此特定示例中的下拉选择更改内容?

这是我尝试过的:

  <select class="selection-of-areas" id="selection-of-area" onchange="changeFunc();">
<option value="illinois">Illinois</option>
<option value="florida">Florida</option>
  </select>
</div>

<div class="members-row illinois-members">
 Test Illinois
</div>

<div class="members-row florida-members">
Test Florida
</div>

而js...

function changeFunc() {
    var selectBox = document.getElementById("selection-of-area");
    var selectedValue = selectBox.options[selectBox.selectedIndex].value;
   }


(function($) {
  $('.select-button').click(function(e) {
    e.preventDefault();
    var $this = $(this),
      $targetRow = $this.data('target'),
      $activeClassText = 'active';
    $('.select-button').removeClass($activeClassText);
    $this.addClass($activeClassText);
    $('.members-row').removeClass($activeClassText);
    $('.' + $targetRow + '-members').addClass($activeClassText);
  });
})(jQuery)

CSS:

.selection-of-areas {
    width: 100%;
    font-family: 'Josefin Sans';
    font-size: 18px;
    background: #eee;
    padding: 11px 9px 8px;
    box-shadow: 0 0 3px rgba(120,120,120,.5);
}

.select-area-selection {
    display: block;
}

.members-row.active {
    display: block;
}

.members-row {
    display: none;
}

我在这里创建了一个codepen: https://codepen.io/gpercifield/pen/MWyKYeG

它似乎根本没有火。 感谢您为我指明正确方向的任何帮助。

你可以使用这样的东西:

$('.members-row').hide();
$('.' + selectedValue +'-members').show();

如果你想在 javascript 中使用它:

var hideele = document.querySelectorAll('.members-row');
for (var i = 0; i < hideele.length; i++) {
  hideele[i].style.display = 'none';
}
document.querySelectorAll('.' + selectedValue + '-members')[0].style.display = 'block';

演示

 function changeFunc() { var selectBox = document.getElementById("selection-of-area"); var selectedValue = selectBox.options[selectBox.selectedIndex].value; $('.members-row').hide(); $('.' + selectedValue +'-members').show(); }
 .selection-of-areas { width: 100%; font-family: 'Josefin Sans'; font-size: 18px; background: #eee; padding: 11px 9px 8px; box-shadow: 0 0 3px rgba(120, 120, 120, .5); }.select-area-selection { display: block; }.members-row.active { display: block; }.members-row { display: none; }
 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <select class="selection-of-areas" id="selection-of-area" onchange="changeFunc();"> <option value="illinois">Illinois</option> <option value="florida">Florida</option> </select> <div class="members-row illinois-members"> Test Illinois </div> <div class="members-row florida-members"> Test Florida </div>

您只需要一个 function 即可在下拉列表更改时触发。

function changeFunc(event) {
var selectBox = document.getElementById("selection-of-area");
var selectedValue = selectBox.options[selectBox.selectedIndex].value;console.log(selectedValue)


// get the value
var activeClassText = 'active';
  $('.members-row').removeClass(activeClassText); // hide others
  $("."+selectedValue+'-members').addClass(activeClassText); // show only which is selected

}

暂无
暂无

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

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