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

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

May 16, 2016 pm 06:29 PM
js Cekap

在使用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;
}
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

<🎜>: Bubble Gum Simulator Infinity - Cara Mendapatkan dan Menggunakan Kekunci Diraja
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Cara Membuka Kunci Cangkuk Bergelut
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Sistem Fusion, dijelaskan
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial Java
1667
14
Tutorial PHP
1273
29
Tutorial C#
1255
24
Disyorkan: Projek pengesanan dan pengecaman muka sumber terbuka JS yang sangat baik Disyorkan: Projek pengesanan dan pengecaman muka sumber terbuka JS yang sangat baik Apr 03, 2024 am 11:55 AM

Teknologi pengesanan dan pengecaman muka adalah teknologi yang agak matang dan digunakan secara meluas. Pada masa ini, bahasa aplikasi Internet yang paling banyak digunakan ialah JS Melaksanakan pengesanan muka dan pengecaman pada bahagian hadapan Web mempunyai kelebihan dan kekurangan berbanding dengan pengecaman muka bahagian belakang. Kelebihan termasuk mengurangkan interaksi rangkaian dan pengecaman masa nyata, yang sangat memendekkan masa menunggu pengguna dan meningkatkan pengalaman pengguna termasuk: terhad oleh saiz model, ketepatannya juga terhad. Bagaimana untuk menggunakan js untuk melaksanakan pengesanan muka di web? Untuk melaksanakan pengecaman muka di Web, anda perlu biasa dengan bahasa dan teknologi pengaturcaraan yang berkaitan, seperti JavaScript, HTML, CSS, WebRTC, dll. Pada masa yang sama, anda juga perlu menguasai visi komputer yang berkaitan dan teknologi kecerdasan buatan. Perlu diingat bahawa kerana reka bentuk bahagian Web

Ciri dan Kelebihan Bahasa C: Mengapakah ia merupakan salah satu bahasa pengaturcaraan yang paling popular? Ciri dan Kelebihan Bahasa C: Mengapakah ia merupakan salah satu bahasa pengaturcaraan yang paling popular? Feb 23, 2024 am 08:39 AM

Ciri dan Kelebihan Bahasa C: Mengapakah ia merupakan salah satu bahasa pengaturcaraan yang paling popular? Sebagai bahasa pengaturcaraan peringkat tinggi tujuan umum, bahasa C mempunyai banyak ciri dan kelebihan unik, itulah sebabnya ia telah menjadi salah satu bahasa pengaturcaraan yang paling popular. Artikel ini akan meneroka ciri dan kelebihan bahasa C, serta aplikasinya yang meluas dalam pelbagai bidang. Pertama sekali, bahasa C mempunyai sintaks yang ringkas dan struktur yang jelas. Berbanding dengan bahasa pengaturcaraan lain, sintaks bahasa C agak mudah dan mudah difahami dan dipelajari. Ia menggunakan ciri-ciri bahasa semula jadi untuk membolehkan pengaturcara

Hubungan antara js dan vue Hubungan antara js dan vue Mar 11, 2024 pm 05:21 PM

Hubungan antara js dan vue: 1. JS sebagai asas pembangunan Web; 2. Kebangkitan Vue.js sebagai rangka kerja hadapan 3. Hubungan pelengkap antara JS dan Vue; Vue.

Pemahaman mendalam tentang fungsi dan ciri bahasa Go Pemahaman mendalam tentang fungsi dan ciri bahasa Go Mar 21, 2024 pm 05:42 PM

Fungsi dan ciri bahasa Go bahasa Go, juga dikenali sebagai Golang, ialah bahasa pengaturcaraan sumber terbuka yang dibangunkan oleh Google Ia pada asalnya direka untuk meningkatkan kecekapan dan kebolehselenggaraan pengaturcaraan. Sejak kelahirannya, bahasa Go telah menunjukkan daya tarikan uniknya dalam bidang pengaturcaraan dan telah mendapat perhatian dan pengiktirafan yang meluas. Artikel ini akan menyelidiki fungsi dan ciri bahasa Go dan menunjukkan kuasanya melalui contoh kod tertentu. Sokongan serentak asli Bahasa Go sememangnya menyokong pengaturcaraan serentak, yang dilaksanakan melalui mekanisme goroutine dan saluran.

Ruang pemacu C kehabisan! 5 kaedah pembersihan yang cekap didedahkan! Ruang pemacu C kehabisan! 5 kaedah pembersihan yang cekap didedahkan! Mar 26, 2024 am 08:51 AM

Ruang pemacu C kehabisan! 5 kaedah pembersihan yang cekap didedahkan! Dalam proses menggunakan komputer, ramai pengguna akan menghadapi situasi di mana ruang pemacu C kehabisan terutamanya selepas menyimpan atau memasang sejumlah besar fail, ruang pemacu C yang tersedia akan berkurangan dengan cepat, yang akan menjejaskan prestasi dan. kelajuan komputer berjalan. Pada masa ini, sangat perlu untuk membersihkan pemacu C. Jadi, bagaimana untuk membersihkan pemacu C dengan cekap? Seterusnya, artikel ini akan mendedahkan 5 kaedah pembersihan yang cekap untuk membantu anda menyelesaikan masalah kekurangan ruang pemacu C dengan mudah. 1. Bersihkan fail sementara ialah fail sementara yang dijana semasa komputer sedang berjalan.

Panduan penukaran amalan pengekodan golang yang cekap Panduan penukaran amalan pengekodan golang yang cekap Feb 20, 2024 am 11:09 AM

Tajuk: Panduan Amalan Cekap untuk Penukaran Pengekodan Bahasa Go Dalam pembangunan perisian harian, kita sering menghadapi keperluan untuk menukar teks dalam pengekodan yang berbeza. Sebagai bahasa pengaturcaraan yang cekap dan moden, bahasa Go menyediakan perpustakaan standard yang kaya dan fungsi terbina dalam, menjadikannya sangat mudah dan cekap untuk melaksanakan penukaran pengekodan teks. Artikel ini akan memperkenalkan garis panduan praktikal tentang cara melakukan penukaran pengekodan dalam bahasa Go dan memberikan contoh kod khusus. 1.Pengekodan UTF-8 dan penukaran rentetan Dalam bahasa Go, rentetan menggunakan pengekodan UTF-8 secara lalai

Membandingkan kos pembelajaran Python dan C++: Mana satu yang lebih bernilai pelaburan? Membandingkan kos pembelajaran Python dan C++: Mana satu yang lebih bernilai pelaburan? Mar 25, 2024 pm 10:24 PM

Python dan C++ ialah dua bahasa pengaturcaraan yang popular, masing-masing mempunyai kelebihan dan kekurangannya sendiri. Bagi orang yang ingin belajar pengaturcaraan, memilih untuk belajar Python atau C++ selalunya merupakan keputusan penting. Artikel ini akan meneroka kos pembelajaran Python dan C++ dan membincangkan bahasa yang lebih sesuai untuk masa dan usaha. Mula-mula, mari kita mulakan dengan Python. Python ialah bahasa pengaturcaraan peringkat tinggi yang ditafsirkan yang terkenal dengan kemudahan pembelajaran, kod yang jelas dan sintaks yang ringkas. Berbanding dengan C++, Python

Perbezaan antara __proto__ dan prototaip dalam JS Perbezaan antara __proto__ dan prototaip dalam JS Feb 19, 2024 pm 01:38 PM

__proto__ dan prototaip ialah dua atribut yang berkaitan dengan prototaip dalam JS Mereka mempunyai fungsi yang sedikit berbeza. Artikel ini akan memperkenalkan dan membandingkan perbezaan antara kedua-duanya secara terperinci, dan memberikan contoh kod yang sepadan. Pertama, mari kita fahami maksudnya dan untuk kegunaannya. proto__proto__ ialah sifat terbina dalam objek yang menunjuk kepada prototaip objek. Setiap objek mempunyai atribut __proto__, termasuk objek tersuai, objek terbina dalam dan objek fungsi. Oleh __proto__ genus

See all articles