控件中国网现已改版,您看到的是老版本网站的镜像,系统正在为您跳转到新网站首页,请稍候.......
中国最专业的商业控件资讯网产品咨询电话:023-67870900 023-67871946
产品咨询EMAIL:SALES@COMPONENTCN.COM

对《30个提高Web程序执行效率的好经验》的理解

作者:葡萄城 出处:葡萄城 2010年09月01日 阅读:

8. 如果你需要把多个字符串连接起来,最好是把他们做成一个数组,然后调用join()方法实现这个操作。这种方式在生成HTML片段时尤其 有效。

验证还是用测试代码:

01 function testNoJoin(){
02 var startTime = new Date();
03 var testStr = "abcdefghqwertyuiolkjmzxv";
04 var result = "";
05 for(var i=0; i<50000; i++) result += testStr;
06 document.getElementById('divShowTime1').innerHTML = '耗时1:' +  (new Date() - startTime) + 'ms';
07 }
08 function testJoin(){
09 var startTime = new Date();
10 var testStr = "abcdefghqwertyuiolkjmzxv";
11 var result = "";
12 var strs = new Array();
13 for(var i=0; i<50000; i++) strs[i] = testStr;
14 result = strs.join("");
15 document.getElementById('divShowTime2').innerHTML = '耗时2:' +  (new Date() - startTime) + 'ms';
16 strs = null;
17 }

 

测试结果:

  IE8 Firefox Chrome
1

耗时1:19ms
耗时2:25ms

耗时1:25ms
耗时2:25ms

耗时1:15ms
耗时2:9ms

2

耗时1:28ms
耗时2:25ms

耗时1:24ms
耗时2:25ms

耗时1:16ms
耗时2:8ms

3

耗时1:17ms
耗时2:25ms

耗时1:25ms
耗时2:25ms

耗时1:4ms
耗时2:8ms

4

耗时1:16ms
耗时2:25ms

耗时1:28ms
耗时2:27ms

耗时1:4ms
耗时2:11ms

 

可以看出,这条规则在主流的浏览器中,效率的差别不大。IE6下测试,的确第一种比第二种方式效率差很多,所以这条规则已经过时了。

热推产品

  • ActiveReport... 强大的.NET报表设计、浏览、打印、转换控件,可以同时用于WindowsForms谀坔攀戀Forms平台下......
  • AnyChart AnyChart使你可以创建出绚丽的交互式的Flash和HTML5的图表和仪表控件。可以用于仪表盘的创......
首页 | 新闻中心 | 产品中心 | 技术文档 | 友情连接 | 关于磐岩 | 技术支持中心 | 联系我们 | 帮助中心 Copyright-2006 ComponentCN.com all rights reserved.重庆磐岩科技有限公司(控件中国网) 版权所有 电话:023 - 67870900 传真:023 - 67870270 产品咨询:sales@componentcn.com 渝ICP备12000264号 法律顾问:元炳律师事务所 重庆市江北区塔坪36号维丰创意绿苑A座28-5 邮编:400020
在线客服
在线客服系统
在线客服
在线客服系统