How To Filter By Hiding/showing Divs With Dynamic Attributes?
Solution 1:
Why not add the following attribute to your checkboxs data-target='div#'
Then assign your divs ID the same value.
then with js:
$(document).on('click', '.checkboxs', function() {
var t = $(this).attr('data-target');
if(t != undefined) {
//check if its already shown, if so hide!
if($(this).attr('data-isshown')) {
$("#"+t).hide();
$(this).removeAttr('data-isshown')
} else {
$("#"+t).show();
$(this).attr("data-isshown", true);
}
}
});
Solution 2:
finally I figured it out, I loop through all checkboxes and all divs
<script type="text/javascript" src="http://code.jquery.com/jquery.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$('input[type="checkbox"]').click(function(){
var numberOfChecked = $('input:checkbox:checked').length;
$(".clearfix").each(function(){
var clear=$(this);
$('input[type="checkbox"]').each(function(){
var variable=$(this);
var flag=$(this).prop('checked');
var id=$(this).val();
if(flag)
{
if(clear.attr("value")==variable.val())
{
var id=clear.attr("value");
var x=document.getElementById(id);
x.style.display="block";
clear.css('display','block');
}
}
else if(clear.attr("value")==variable.val())
{ var id=clear.attr("value");
var x=document.getElementById(id);
x.style.display="none";
clear.css('display','none');
}
if(!numberOfChecked)
{
var id=clear.attr("value");
var x=document.getElementById(id);
x.style.display="block";
clear.css('display','block');
}
}); //clear
});//all checkboxes
}); //click
});//ready
Solution 3:
Please forgive me if I misunderstood your question, but you can accomplish this with CSS alone using the general sibling combinator:
<input type="checkbox" class="box_a" />
<input type="checkbox" class="box_b" />
<div class="box" id="a">This is a box.</div>
<div class="box" id="b">This is b box.</div>
.box {
display: none;
}
.box_a:checked ~ #a,
.box_b:checked ~ #b {
display: block;
}
Demo: http://jsfiddle.net/jonathansampson/dXKLL/
If you're not able to control the id values, you could base the connection on nth-of-type
:
.check:nth-of-type(1):checked ~ .box:nth-of-type(1),
.check:nth-of-type(2):checked ~ .box:nth-of-type(2) {
display: block;
}
Demo: http://jsfiddle.net/jonathansampson/dXKLL/1/
If you need everything to be visible when no checkboxes are checked, you could use both the next sibling selector along with the general sibling selector:
.check:not(:checked) + .check:not(:checked) ~ .box {
display: block;
}
This will show all .box
elements that follow at least two unchecked .check
elements.
Post a Comment for "How To Filter By Hiding/showing Divs With Dynamic Attributes?"