首頁 web前端 js教程 JS下高效拼装字符串的几种方法比较与测试代码_javascript技巧

JS下高效拼装字符串的几种方法比较与测试代码_javascript技巧

May 16, 2016 pm 06:29 PM
js 高效率

在使用Ajax提交信息时,我可能常常需要拼装一些比较大的字符串通过XmlHttp来完成POST提交。尽管提交这样大的信息的做法看起来并不优雅,但有时我们可能不得不面对这样的需求。那么JavaScript中对字符串的累加速度如何呢?我们先来做下面的这个实验。累加一个长度为30000的字符串。
测试代码1 - 耗时: 14.325秒

复制代码 代码如下:

var str = "";
for (var i = 0; i str += "xxxxxx";
}

这段代码耗时14.325秒,结果并不理想。现在我们将代码改为如下的形式:
测试代码2 - 耗时: 0.359秒
复制代码 代码如下:

var str = "";
for (var i = 0; i var sub = "";
for (var j = 0; j sub += "xxxxxx";
}
str += sub;
}

这段代码耗时0.359秒!同样的结果,我们做的只是首先拼装一些较小的字符串然后再组装成更大的字符串。这种做法可以有效的在字符串拼装的后期减小内存复制的数据量。知道了这一原理之后我们还可以把上面的代码进一步拆散以后进行测试。下面的代码仅耗时0.140秒。
测试代码3 - 耗时: 0.140秒
复制代码 代码如下:

var strArray = new Array();
for (var i = 0; i var sub = "";
for (var j = 0; 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 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;
}
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1421
52
Laravel 教程
1315
25
PHP教程
1266
29
C# 教程
1239
24
建議:優秀JS開源人臉偵測辨識項目 建議:優秀JS開源人臉偵測辨識項目 Apr 03, 2024 am 11:55 AM

人臉偵測辨識技術已經是一個比較成熟且應用廣泛的技術。而目前最廣泛的網路應用語言非JS莫屬,在Web前端實現人臉偵測辨識相比後端的人臉辨識有優勢也有弱勢。優點包括減少網路互動、即時識別,大大縮短了使用者等待時間,提高了使用者體驗;弱勢是:受到模型大小限制,其中準確率也有限。如何在web端使用js實現人臉偵測呢?為了實現Web端人臉識別,需要熟悉相關的程式語言和技術,如JavaScript、HTML、CSS、WebRTC等。同時也需要掌握相關的電腦視覺和人工智慧技術。值得注意的是,由於Web端的計

C語言的特色和優點:為什麼它成為最受歡迎的程式語言之一? C語言的特色和優點:為什麼它成為最受歡迎的程式語言之一? Feb 23, 2024 am 08:39 AM

C語言的特色和優點:為什麼它成為最受歡迎的程式語言之一?作為一門通用的高階程式語言,C語言具有許多獨特的特點和優勢,這也是為什麼它成為最受歡迎的程式語言之一的原因。本文將探討C語言的特點和優勢,以及它在各領域的廣泛應用。首先,C語言具有簡潔的語法和清晰的結構。相較於其他程式語言而言,C語言的語法相對簡單,易於理解和學習。它採用了自然語言的特點,使得程式設計人員能

js和vue的關係 js和vue的關係 Mar 11, 2024 pm 05:21 PM

js和vue的關係:1、JS作為Web開發基石;2、Vue.js作為前端框架的崛起;3、JS與Vue的互補關係;4、JS與Vue的實踐應用。

C盤空間告急! 5種高效率清理方法大揭密! C盤空間告急! 5種高效率清理方法大揭密! Mar 26, 2024 am 08:51 AM

C盤空間告急! 5種高效率清理方法大揭密!在使用電腦的過程中,不少用戶會遇到C盤空間告急的情況,尤其是在儲存或安裝大量檔案後,C碟的可用空間會迅速減少,進而影響電腦效能和運作速度。此時,對C盤進行清理是十分必要的。那麼,該如何有效率地清理C盤呢?接下來,本文將揭示5種高效率的清理方法,幫助您輕鬆解決C盤空間抱怨的問題。一、清理臨時檔案臨時檔案是電腦在運作時產生的一些暫

深入了解Go語言的功能與特點 深入了解Go語言的功能與特點 Mar 21, 2024 pm 05:42 PM

Go語言的功能與特色Go語言,又稱Golang,是一種由Google開發的開源程式語言,設計初衷是為了提升程式效率和可維護性。自誕生以來,Go語言在程式設計領域展現了獨特的魅力,並受到了廣泛的關注和認可。本文將深入探討Go語言的功能與特點,並透過具體的程式碼範例來展示其強大之處。原生並發支援Go語言天生支援並發編程,透過goroutine和channel的機制實現

指導高效轉換golang編碼實踐 指導高效轉換golang編碼實踐 Feb 20, 2024 am 11:09 AM

標題:Go語言編碼轉換高效實踐指南在日常的軟體開發中,我們經常會遇到需要對不同編碼的文本進行轉換的需求。 Go語言作為一種高效、現代化的程式語言,提供了豐富的標準函式庫和內建函數,使得實現文字編碼轉換變得非常簡單和有效率。本文將介紹如何在Go語言中進行編碼轉換的實踐指南,並提供具體的程式碼範例。 1.UTF-8編碼與字串轉換在Go語言中,字串預設採用UTF-8編碼

比較Python和C++學習成本:哪個比較值得投入? 比較Python和C++學習成本:哪個比較值得投入? Mar 25, 2024 pm 10:24 PM

Python和C++是兩種流行的程式語言,各有其優點和缺點。對於希望學習程式設計的人來說,選擇學習Python還是C++往往是一個重要決定。本文將探討Python和C++的學習成本,並討論哪種語言較值得投入時間與精力。首先,讓我們從Python開始。 Python是一種高階、解釋型的程式語言,以其簡單易學、程式碼清晰、語法簡潔等特色而聞名。相較於C++,Python

JS中__proto__與prototype的差別 JS中__proto__與prototype的差別 Feb 19, 2024 pm 01:38 PM

JS中__proto__和prototype是兩個與原型相關的屬性,它們在功能上稍有不同。本文將具體介紹並比較這兩者的區別,並提供相應的程式碼範例。首先,我們先來了解它們的意義和用途。 proto__proto__是物件的內建屬性,它用來指向該物件的原型。每個物件都有一個__proto__屬性,包括自訂物件、內建物件和函數物件。透過__proto__屬

See all articles