zoukankan      html  css  js  c++  java
  • js便签笔记(3)——切记:appendChild()、insertBefore()是移动element节点!

    appendChild()、insertBefore()是移动element节点,看书的时候注意过,也可以做一个简单的例子测试一下:

    <div id="div1">
        <p id="p1" style="background-color:blue">2014</p>
    </div>
    <hr />
    <div id="div2"></div>
    
    
    var div1 = document.getElementById("div1");
    var div2 = document.getElementById("div2");
    var p1 = document.getElementById("p1");
    
    div2.appendChild(p1);

    以上代码中,P本来是在div1中,hr的上面,执行了appendChild()之后,就移动到了div2中,hr下面了:

    但是今天我在一个实际工作中,却忽略了这一问题。代码过程如下:

    1. 用js创建一个5000 * 100的table,保存到一个临时的div中;

    2. 取出这个table的前100行,加载到页面上的一个table中;

    代码如下:

     1 <table id="tableContent" cellpadding="0" cellspacing="0"></table>
     2 
     3 var tableContent = document.getElementById("tableContent");
     4 
     5 var trNum = 5000,
     6       tdNum = 100,
     7       html = "",
     8       tempDiv = document.createElement("div");
     9 
    10 //创建 5000 * 100 的table,并放在临时div中
    11 html += "<table>";
    12 for (i = 0; i < trNum; i++) {
    13                 html += "<tr>";
    14 
    15                 for (j = 0; j < tdNum; j++) {
    16                     html += "<td>" + i + "|" + j + "</td>";
    17                 }
    18 
    19                 html += "</tr>";
    20 }
    21 html += "</table>";
    22 tempDiv.innerHTML = html;
    23 
    24 //取出前100行,加载到tableContent 上
    25 var trs = tempDiv.firstChild.firstChild.childNodes,
    26       trLen = trs.length;
    27       tempTbody = document.createElement("tbody");
    28 
    29 for (i = 0; i < 100 && i < trLen; i++) {
    30     tempTbody.appendChild(trs[i]);                         //出问题的地方!
    31 }
    32 
    33 tableContent.appendChild(tempTbody);

    问题的原因:

    创建一个table,保存到临时的div中。然后再取出这个div,找到table的所有行tr,保存到trs中。

    然后循环trs集合,取出前100个,添加到临时的tbody上,问题就出现在这里。

    for (i = 0; i < 100 && i < trLen; i++) {
         tempTbody.appendChild(trs[i]);                         
    }

    当我每执行一次tempTbody.appendChild(trs[i])的时候,其实都是从trs中移除一个元素,trs的长度会越来越小,因此得不到我想要的结果。

    要解决这一问题,很简单,只需加上.cloneNode(true)即可。

    for (i = 0; i < 100 && i < trLen; i++) {
         tempTbody.appendChild(trs[i].cloneNode(true));                         
    }

    这种鸡毛蒜皮的问题,有时候还是需要多注意,多积累。且行且珍惜,且写且注意啊!

  • 相关阅读:
    使用selenium操作ant design前端的页面,感觉页面没加载完
    centos7上PhantomJS 过期之后改用Chrome时填的坑
    《追风行动》有点儿意思
    《听读书怪才解读24部名人传记》笔记
    mysql 8.0 密码加密方式的坑
    huginn website agent对提取结果排序
    Server酱微信推送中的问题
    Huginn定时时间不准确或延后问题
    一本通1219 马走日
    矩阵快速幂
  • 原文地址:https://www.cnblogs.com/wangfupeng1988/p/3639248.html
Copyright © 2011-2022 走看看