JS字符串累加
来源:互联网 发布:金蝶eas数据字典 编辑:程序博客网 时间:2024/04/30 08:19
在使用Ajax提交信息时,我可能常常需要拼装一些比较大的字符串通过XmlHttp来完成POST提交。尽管提交这样大的信息的做法看起来并不优雅,但有时我们可能不得不面对这样的需求。那么JavaScript中对字符串的累加速度如何呢?我们先来做下面的这个实验。累加一个长度为30000的字符串。
测试代码1 - 耗时: 14.325秒
复制代码 代码如下:
var str = "";
for (var i = 0; i < 50000; i++) {
str += "xxxxxx";
}
这段代码耗时14.325秒,结果并不理想。现在我们将代码改为如下的形式:
测试代码2 - 耗时: 0.359秒
复制代码 代码如下:
var str = "";
for (var i = 0; i < 100; i++) {
var sub = "";
for (var j = 0; j < 500; j++) {
sub += "xxxxxx";
}
str += sub;
}
这段代码耗时0.359秒!同样的结果,我们做的只是首先拼装一些较小的字符串然后再组装成更大的字符串。这种做法可以有效的在字符串拼装的后期减小内存复制的数据量。知道了这一原理之后我们还可以把上面的代码进一步拆散以后进行测试。下面的代码仅耗时0.140秒。
测试代码3 - 耗时: 0.140秒
复制代码 代码如下:
var strArray = new Array();
for (var i = 0; i < 100; i++) {
var sub = "";
for (var j = 0; j < 500; j++) {
sub += "xxxxxx";
}
strArray.push(sub);
}
str = String.prototype.concat.apply("", strArray);
不过,上面这种做法也许并不是最好的!如果我们需要提交的信息是XML格式的(其实绝大多数情况下,我们都可以设法将要提交的信息组装成XML格式),我们还能找能更高效更优雅的方法—利用DOM对象为我们组装字符串。下面这段代买组装一个长度为950015的字符串仅须耗时0.890秒。
利用DOM对象组装信息 - 耗时: 0.890秒
复制代码 代码如下:
var xmlDoc;
if (browserType == BROWSER_IE) {
xmlDoc = new ActiveXObject("Msxml.DOMDocument");
}
else {
xmlDoc = document.createElement("DOM");
}
var root = xmlDoc.createElement("root");
for (var i = 0; i < 50000; i++) {
var node = xmlDoc.createElement("data");
if (browserType == BROWSER_IE) {
node.text = "xxxxxx";
}
else {
node.innerText = "xxxxxx";
}
root.appendChild(node);
}
xmlDoc.appendChild(root);
var str;
if (browserType == BROWSER_IE) {
str = xmlDoc.xml;
}
else {
str = xmlDoc.innerHTML;
}
详细出处参考:http://www.jb51.net/article/23073.htm
- JS字符串累加
- SQL 字符串累加
- MySQL 字符串累加 SQL
- 字符串累加的效率
- java正确使用字符串累加
- mysql的字符串格式化+累加
- sqlserver function(函数) 字符串累加
- 字符串类型的数字累加
- JS常见算法-累加/累积
- 累加
- 累加
- 累加
- JAVA中正确使用字符串累加
- Java中字符串累加的性能优化
- SQL 根据条件实现字符串累加
- 编译器将字符串累加编译成StringBuilder
- java数字字符串累加1的解决方案
- Sql查询结果字符串累加(转)
- 【转】MSN,QQ在线即时交谈网页代码
- JSF学习总结篇
- 【转】在网页嵌入QQ+MSN+淘宝旺旺+Gtalk快速对话框官方代码的方法
- 输入自动完成
- 【转】在网页中嵌入QQ 阿里旺旺 淘宝代码及详解
- JS字符串累加
- Visual Studio 11新特性
- Oracle 的 MERGE用法
- 【转】绝对地址对比相对地址更利于搜索引擎优化
- 背包
- 【转】小修改让点击数(浏览量)变得更随机
- 服务器出现500错误
- 动态规划解最长公共子序列问题
- 动态规划--概览