如何高效的拼装字符串
来源:互联网 发布:2017手机淘宝怎么开店 编辑:程序博客网 时间:2024/04/29 03:56
在使用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秒
ar 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;
}
- 如何高效的拼装字符串
- javascript如何快速拼装html字符串?
- JS拼装html字符串的最快方法
- 拼装html字符串的最快方法
- IOS 拼装where后的动态字符串
- Go语言中字符串的拼装方法
- 拼装json字符串
- StringJoiner 拯救那些性能低下的字符串拼装代码
- ASP.NET 拼装Url字符串 需要传中文的解决方案
- 循环拼装String字符串去掉最后一个字符的方法
- js拼装查询条件字符串
- 高效的字符串倒置
- 高效的字符串移动
- ios 字符串拼接 字符串拼装 NSString连接
- 如何高效的工作
- 如何高效的工作
- 如何高效的学习
- 如何高效的工作
- 何为粗、细粒度
- 关于MySql字符集的问题
- 抽象类与接口
- DHC log 2009-5-5 6 7
- 10.3将图像作为列表项标记
- 如何高效的拼装字符串
- 10.4放置列表标记
- HQL的语法和使用
- 兼容低版本 IE 的 JScript 5.5 实现
- windows EFS加密文件(夹)
- 内存分配
- 10.5css列表属性
- 取得任意两个日期相隔的整月数
- 想要成为搜索软件工程师,这不在是梦想!!!