为每个父母创建一个 div?

如何解决为每个父母创建一个 div?

我需要用 div 包裹父级的所有子级。在下面的示例中,我设法在每个父级之后放置了一个 div 标签,但如何在 chidrens 的末尾放置一个结束 /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>

解决方法

如果您想将每个父项下的所有 div 包含在一个新的 div 中,您可以创建一个新的 div 元素,将所有非文本子项移动到它,然后将该 div 作为子项添加到原始父项中:

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>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?