http://www.aygfsteel.com/ebecket 返還網
          隨筆-140  評論-11  文章-131  trackbacks-0
          HTML code
          <!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選中和取消的速度是一樣,實際上也差不多
          posted on 2009-11-04 16:40 becket_zheng 閱讀(1980) 評論(0)  編輯  收藏 所屬分類: 網頁web前端技術
          主站蜘蛛池模板: 永康市| 永丰县| 喀喇沁旗| 虞城县| 阿荣旗| 石台县| 金阳县| 西城区| 株洲市| 甘孜| 常州市| 康定县| 清水县| 榆社县| 砀山县| 永康市| 东光县| 乡城县| 新密市| 上饶县| 民权县| 克什克腾旗| 康乐县| 玛沁县| 台前县| 赣榆县| 随州市| 庄浪县| 齐齐哈尔市| 新野县| 太保市| 邵阳县| 武清区| 长兴县| 新巴尔虎左旗| 正安县| 皮山县| 奉化市| 博白县| 嘉定区| 安图县|