ul建立1000個li

最近看到的一個問題:如果讓你在ul下建立1000個li,你會怎麼做?

1、當時我想到的笨辦法是利用循環添加子節點,如下例

當數目增長到10000的時候,出現了明顯的時延

[javascript] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. window.onload = function(){  
  2.         var oUi = document.getElementsByTagName("ul");  
  3.         //var oUi1 = oUi[0];  
  4.         for(var i=0;i<9998;i++){  
  5.             var oLi = document.createElement("li");  
  6.             oLi.innerHTML = "li";  
  7.             oUi[0].appendChild(oLi);  
  8.         }  
  9.     };  

2、然後後來又想到,可以直接構造字符串,然後更替ul的innerHTML,如下例

當數目增至100000個的時候,纔會出現明顯時延

[javascript] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. <script type="text/javascript">  
  2.         window.onload = function(){  
  3.             var oUi = document.getElementsByTagName("ul");  
  4.             var str = "";  
  5.             for(var i=0;i<999998;i++){  
  6.                 str += "<li>li</li>";  
  7.             }  
  8.             oUi[0].innerHTML = str;   
  9.         }  
  10.     </script>  

3、後來又看到網上說,join拼接字符串的效率要比str+=要高,因此,又採用join的做法對方法2做出了改進。

當數目增至1000000個的時候,纔會出現明顯時延

[javascript] view plain copy
 在CODE上查看代碼片派生到我的代碼片
  1. window.onload = function(){  
  2.             var arr = new Array();  
  3.             var oUi = document.getElementById("ul");
  4.             arr.push("<li>li");  
  5.             for(var i=0;i<999998;i++){  
  6.                 arr.push("li");  
  7.             }  
  8.             arr.push("li</li>");  
  9.             var oList = arr.join("</li><li>");  
  10.             oUi.innerHTML = oList;  
  11.         };  



擴展,<ul>添加1萬個<li>,通過事件委託,爲每一個<li>添加點擊事件:

<body>
<ul id="ul"></ul>


</body>


<script type = "text/javascript">
window.onload = function(){
var oUi = document.getElementById("ul");
var arr = new Array();
arr.push("<li>li");
for(var i=0; i<99998; i++){
arr.push("li");
}
arr.push("li</li>");
var oList = arr.join("</li><li>");
oUi.innerHTML = oList;
console.log(arr.length);

oUi.addEventListener("click", function(event){
var ev = event || window.event;
var target = ev.target || ev.srcElement;
console.log(target.innerHTML);
if(target.nodeName.toLowerCase() === "li"){
target.style.background = "red";
}
});
}
</script>

發佈了25 篇原創文章 · 獲贊 12 · 訪問量 13萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章