Home > Software design >  how can I hide parent div if all the children are "display:none"
how can I hide parent div if all the children are "display:none"

Time:01-08

I have this HTML block

 <div >
       <div  style="display: none;">xyz</div>
       <div  style="display: none;">xyz</div>
       <div  style="display: none;">xyz</div>
    </div>
    <div >
       <div  style="display: none;">xyz</div>
       <div  style="display: none;">xyz</div>
       <div  style="display: block;">xyz</div>
       <div  style="display: block;">xyz</div>
     </div>

I want to hide all the parent div if it contains all the "display:none" div else I want to show parent div..

CodePudding user response:

This code uses pure JavaScript. First you get a list of all elements of the class abc and create lists for their children. Then you iterate those and check for any display value other than none. If a parents children all go through when they are none you lastly set the parent to display: none otherwise you just break the loop.

let abc = document.getElementsByClassName("abc");
let breaker;

for(i = 0; i < abc.length; i  ) {
    let children = abc[i].children;
  for(x = 0; x < children.length; x  ) {
    let child = children[x];
    if(child.style.display != "none") {
        breaker = true;
    } else { breaker = false }
  }
  if(breaker == true) {continue}
  abc[i].style.display = "none"; // Comment out to see effect
}

I added simple CSS to a fiddle to showcase it. Just comment out the last line abc[i].style.display = "none"; to confirm the effect.

https://jsfiddle.net/h40f8L6o/42/

CodePudding user response:

Try like this using Jquery.

$(".abc").map(function(){
    let flag = true;
    $(this).find(".xyz").map(function(){
       if($(this).css("display") != "none"){
          flag = false;
       }
    });

    if(flag){
       $(this).css("display", "none");
    }else {
       $(this).css("display", "block");
    }
})

CodePudding user response:

Check if the children are all display none:

let parentDiv = // get parent div
let childDivs = parentDiv.childNodes;
let hideParent = true;
for(let i = 0; i < childDivs.length; i  ){
    if(childDivs[i].style.display != "none"){
        hideParent = false;
        break;
    }
}

If so, hide parent:

if(hideParent){
    parentDiv.style.display = "none";
}

CodePudding user response:

I dont see any direct CSS properties will do the trick here. You can use ES to achieve this,

    const parentDiv = document.getElementsByClassName("abc");
    Array.prototype.forEach.call(parentDiv, function (pDiv, i) {
        let isAllDisplayNone = true;
        Array.prototype.forEach.call(pDiv.children, function (cDiv, j) {
            if(cDiv.style.display === "block") {
                isAllDisplayNone = false;
            }
        });
        if(isAllDisplayNone === true)
            pDiv.style.display = "none";
        
    });

Iterate all the parent and child items to identify if all the child items are display none. If so hide the parent element.

  •  Tags:  
  • Related