国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

JS下高效拼裝字符串的幾種方法比較與測試代碼

2019-11-21 00:34:34
字體:
來源:轉載
供稿:網友
在使用Ajax提交信息時,我可能常常需要拼裝一些比較大的字符串通過XmlHttp來完成POST提交。盡管提交這樣大的信息的做法看起來并不優雅,但有時我們可能不得不面對這樣的需求。那么JavaScript中對字符串的累加速度如何呢?我們先來做下面的這個實驗。累加一個長度為30000的字符串。
測試代碼1 - 耗時: 14.325秒
復制代碼 代碼如下:

var str = "";
for (var i = 0; i < 50000; i++) {
str += "xxxxxx";
}

這段代碼耗時14.325秒,結果并不理想?,F在我們將代碼改為如下的形式:
測試代碼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;
}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 济南市| 镇赉县| 石渠县| 澜沧| 淄博市| 三亚市| 华坪县| 普格县| 乌鲁木齐县| 郧西县| 察哈| 台北县| 凌源市| 阜平县| 油尖旺区| 丽江市| 辽源市| 逊克县| 灵璧县| 都兰县| 宁波市| 百色市| 双城市| 郓城县| 广西| 库伦旗| 连云港市| 萨迦县| 习水县| 南岸区| 大埔县| 扶沟县| 胶州市| 卓尼县| 盐边县| 武乡县| 都昌县| 德钦县| 鄯善县| 正宁县| 正宁县|