js中三种遍历数组的效率

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
   
<title>jquery</title>
   
<style type="text/css">
    #info
{
        color
:#FF0000;
        height
:150px;
   
}
   
</style>
</head>
<body>
   
<div id="div1">
   
<input value="5000" type="text" id="txt1"/><input type="button" id="btn1" value="生成 checkbox"/>
   
<div id="info">
   
<input type="button" id="btnTest1" onclick="fun1(this)" value="第一种"/><span></span><br/>
   
<input type="button" id="btnTest1" onclick="fun2(this)" value="第二种"/><span></span><br/>
   
<input type="button" id="btnTest1" onclick="fun3(this)" value="第三种"/><span></span><br/>
   
</div>
   
<div id="box"></div>
   
</div>
</body>
<script type="text/javascript">
var g=function(id) {return document.getElementById(id);};
g(
"btn1").onclick=function() {
   
var val=g("txt1").value-0;
   
if(!isNaN(val)) {
       
var box=g("box");
        box.innerHTML
="";
       
for(var i=0;i<val;i++) {
           
var chk=document.createElement("input");
            chk.type
="checkbox";
            box.appendChild(chk);
        }
    }
}
//这里为了简单就没有判断type
var fun1=function(obj) {//第一种直接在for中取数组长度
    var chks=g("box").getElementsByTagName("input");
   
var b=!chks[0].checked;
   
var d=new Date();
   
for(var i=0;i<chks.length;i++) {
        chks[i].checked
=b;
    }
    obj.nextSibling.innerHTML
=new Date()-d;
}
var fun2=function(obj) {//第二种
    var chks=g("box").getElementsByTagName("input");
   
var b=!chks[0].checked;
   
var d=new Date();
   
for(var i=0;chks[i];i++) {
        chks[i].checked
=b;
    }
    obj.nextSibling.innerHTML
=new Date()-d;
}
var fun3=function(obj) {//第三种将数组的长度放到一个局部变量中
    var chks=g("box").getElementsByTagName("input");
   
var b=!chks[0].checked;
   
var length=chks.length;
   
var d=new Date();
   
for(var i=0;i<length;i++) {
        chks[i].checked
=b;
    }
    obj.nextSibling.innerHTML
=new Date()-d;
}
</script>
</html>

结果:
在5000个chk时,多次测试结果:
第一种方式500毫秒左右
第二种方式大多数是63,少数是46(跟第三种一样)
第三种几乎每次都是46,47的样子
ps:假设checkbox选中和取消的速度是一样,实际上也差不多

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值