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>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值