【问题标题】:Create a div for each parent?为每个父母创建一个div?
【发布时间】:2021-06-09 11:40:15
【问题描述】:

我需要用一个 div 包装父级的所有子级。在下面的示例中,我设法在每个父母之后放置了一个 div 标签,但是如何在孩子的末尾放置一个 end /div 标签。

我尝试使用 document.createElement,现在使用 insertAdjacentHTML ...,解决此问题的最佳方法是什么,或者编码它的最佳方法是什么?

     var divs = document.getElementById("container").querySelectorAll('.activ-window *'); 
     var elements = "";
     divs.forEach(function(elem){
         if (elem.firstChild) {
                    
          elements += elem.insertAdjacentHTML("afterbegin", '<div id="afterParent" style="display:block;">');
                      elem.insertAdjacentHTML("afterend", '</div>');
         }
     });
     document.getElementById("demo").innerHTML = elements;
<div id="container" class="activ-window">

    <div id="parent1">
        <div id="child" ></div>
        <div id="child" ></div>
    </div>
    <div id="parent2">
        <div id="child" ></div>
        <div id="paren3" >
             <div id="child" ></div>
             <div id="child" ></div>
             <div id="child" ></div>
        </div>
    </div>

</div>

应该是这样的:


<div id="container" class="activ-window">

    <div id="parent1">
        <div id="afterParent" style="display:block;">
        <div id="child" ></div>
        <div id="child" ></div>
        </div>
    </div>
    <div id="parent2">
        <div id="afterParent" style="display:block;">
        <div id="child" ></div>
        </div>
        <div id="paren3" >
        <div id="afterParent" style="display:block;">
             <div id="child" ></div>
             <div id="child" ></div>
             <div id="child" ></div>
        </div>
        </div>
    </div>

</div>

为尼克编辑: 这是文本(参见 Parent1):

    <div id="parent1">Parent1
        <div id="child" >child1</div>
        <div id="child" >child1</div>
    </div>

你的代码我明白了

    <div id="parent1">
        <div id="afterParent" style="display:block;">
        "Parent1"
        <div id="child" >Child1</div>
        <div id="child" >Child1</div>
        </div>
    </div>

应该是这样的:

    <div id="parent1">Parent1
        <div id="afterParent" style="display:block;">
        <div id="child" >Child1</div>
        <div id="child" >Child1</div>
        </div>
    </div>

【问题讨论】:

    标签: foreach parent-child createelement insertafter insertadjacenthtml


    【解决方案1】:

    如果您想将每个父级下方的所有divs 包含在一个新的div 中,您可以创建一个新的div 元素,将所有非文本子级移动到其中,然后添加@987654324 @作为孩子的原始父母:

    const container = document.getElementById("container");
    const parentDivs = container.querySelectorAll('.activ-window div[id^="parent"]');
    
    for (let parent of parentDivs) {
      // create a new div
      let after = document.createElement('div');
      after.id = 'after' + parent.id;
      after.style.display = 'block';
      // move the parent's non-text children to it
      let children = parent.childNodes;
      for (let i = 0; i < children.length; i++) {
        if (children[i].nodeType != Node.TEXT_NODE) {
          after.append(children[i]);
        }
      }
      // and append it to the parent
      parent.appendChild(after);
    }
    
    console.log(container.innerHTML);
    <div id="container" class="activ-window">
      <div id="parent1">
        Parent1
        <div id="child1"></div>
        <div id="child2"></div>
      </div>
      <div id="parent2">
        Parent2
        <div id="child3"></div>
        <div id="parent3">
          <div id="child4"></div>
          <div id="child5"></div>
          <div id="child6"></div>
        </div>
      </div>
    </div>

    【讨论】:

    • 这正是所需要的。唯一的问题是,如果将文本添加到父 html 之后会切换到 afterparent。为了更好地解释,我对我的代码示例进行了编辑,请参见上面为 Nick 编辑...
    • @maja 看到我的编辑;我认为这就是你想要的。不幸的是,它有点复杂......
    • 完美答案
    • @maja 很高兴听到 - 我很高兴这就是你要找的。​​span>
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2015-08-10
    • 2018-09-04
    • 2017-11-11
    • 2017-08-27
    • 2012-12-22
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多