Removing elements by class name?

后端 未结 16 1717
猫巷女王i
猫巷女王i 2020-11-27 12:06

I have the below code to find elements with their class name:

// Get the element by their class name
var cur_columns = document.getElementsByClassName(\'colu         


        
16条回答
  •  栀梦
    栀梦 (楼主)
    2020-11-27 12:50

    Brett - are you aware that getElementyByClassName support from IE 5.5 to 8 is not there according to quirksmode?. You would be better off following this pattern if you care about cross-browser compatibility:

    • Get container element by ID.
    • Get needed child elements by tag name.
    • Iterate over children, test for matching className property.
    • elements[i].parentNode.removeChild(elements[i]) like the other guys said.

    Quick example:

    var cells = document.getElementById("myTable").getElementsByTagName("td");
    var len = cells.length;
    for(var i = 0; i < len; i++) {
        if(cells[i].className.toLowerCase() == "column") {
            cells[i].parentNode.removeChild(cells[i]);
        }
    }
    

    Here's a quick demo.

    EDIT: Here is the fixed version, specific to your markup:

    var col_wrapper = document.getElementById("columns").getElementsByTagName("div");
    
    var elementsToRemove = [];
    for (var i = 0; i < col_wrapper.length; i++) {
        if (col_wrapper[i].className.toLowerCase() == "column") {
            elementsToRemove.push(col_wrapper[i]);
        }
    }
    for(var i = 0; i < elementsToRemove.length; i++) {
        elementsToRemove[i].parentNode.removeChild(elementsToRemove[i]);
    }
    

    The problem was my fault; when you remove an element from the resulting array of elements, the length changes, so one element gets skipped at each iteration. The solution is to store a reference to each element in a temporary array, then subsequently loop over those, removing each one from the DOM.

    Try it here.

提交回复
热议问题