Maison interface Web js tutoriel 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;
}
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Recommandé : Excellent projet de détection et de reconnaissance des visages open source JS Apr 03, 2024 am 11:55 AM

La technologie de détection et de reconnaissance des visages est déjà une technologie relativement mature et largement utilisée. Actuellement, le langage d'application Internet le plus utilisé est JS. La mise en œuvre de la détection et de la reconnaissance faciale sur le front-end Web présente des avantages et des inconvénients par rapport à la reconnaissance faciale back-end. Les avantages incluent la réduction de l'interaction réseau et de la reconnaissance en temps réel, ce qui réduit considérablement le temps d'attente des utilisateurs et améliore l'expérience utilisateur. Les inconvénients sont les suivants : il est limité par la taille du modèle et la précision est également limitée ; Comment utiliser js pour implémenter la détection de visage sur le web ? Afin de mettre en œuvre la reconnaissance faciale sur le Web, vous devez être familier avec les langages et technologies de programmation associés, tels que JavaScript, HTML, CSS, WebRTC, etc. Dans le même temps, vous devez également maîtriser les technologies pertinentes de vision par ordinateur et d’intelligence artificielle. Il convient de noter qu'en raison de la conception du côté Web

Caractéristiques et avantages du langage C : Pourquoi est-il l'un des langages de programmation les plus populaires ? Caractéristiques et avantages du langage C : Pourquoi est-il l'un des langages de programmation les plus populaires ? Feb 23, 2024 am 08:39 AM

Caractéristiques et avantages du langage C : Pourquoi est-il l'un des langages de programmation les plus populaires ? En tant que langage de programmation généraliste de haut niveau, le langage C présente de nombreuses fonctionnalités et avantages uniques, c'est pourquoi il est devenu l'un des langages de programmation les plus populaires. Cet article explorera les caractéristiques et les avantages du langage C, ainsi que sa large application dans divers domaines. Tout d’abord, le langage C a une syntaxe concise et une structure claire. Comparée à d’autres langages de programmation, la syntaxe du langage C est relativement simple et facile à comprendre et à apprendre. Il utilise les caractéristiques du langage naturel pour permettre aux programmeurs de

L'espace disque C s'épuise ! 5 méthodes de nettoyage efficaces dévoilées ! L'espace disque C s'épuise ! 5 méthodes de nettoyage efficaces dévoilées ! Mar 26, 2024 am 08:51 AM

L’espace disque C s’épuise ! 5 méthodes de nettoyage efficaces dévoilées ! Lors de l'utilisation d'ordinateurs, de nombreux utilisateurs seront confrontés à une situation dans laquelle l'espace du lecteur C s'épuise. Surtout après le stockage ou l'installation d'un grand nombre de fichiers, l'espace disponible sur le lecteur C diminuera rapidement, affectant ainsi les performances de l'ordinateur. vitesse de course. À ce stade, il est absolument nécessaire de nettoyer le lecteur C. Alors, comment nettoyer efficacement le lecteur C ? Ensuite, cet article révélera 5 méthodes de nettoyage efficaces pour vous aider à résoudre facilement le problème du manque d'espace sur le disque C. 1. Nettoyer les fichiers temporaires Les fichiers temporaires sont des fichiers temporaires générés lorsque l'ordinateur est en cours d'exécution.

Comparaison du coût d'apprentissage de Python et du C++ : lequel vaut le plus l'investissement ? Comparaison du coût d'apprentissage de Python et du C++ : lequel vaut le plus l'investissement ? Mar 25, 2024 pm 10:24 PM

Python et C++ sont deux langages de programmation populaires, chacun ayant ses propres avantages et inconvénients. Pour les personnes qui souhaitent apprendre la programmation, choisir d’apprendre Python ou C++ est souvent une décision importante. Cet article explorera les coûts d'apprentissage de Python et C++ et discutera du langage qui mérite le plus de temps et d'efforts. Commençons par Python. Python est un langage de programmation interprété de haut niveau connu pour sa facilité d'apprentissage, son code clair et sa syntaxe concise. Par rapport au C++, Python

La relation entre js et vue La relation entre js et vue Mar 11, 2024 pm 05:21 PM

La relation entre js et vue : 1. JS comme pierre angulaire du développement Web ; 2. L'essor de Vue.js en tant que framework front-end ; 3. La relation complémentaire entre JS et Vue ; Vue.

Guide pour une conversion efficace des pratiques de codage Golang Guide pour une conversion efficace des pratiques de codage Golang Feb 20, 2024 am 11:09 AM

Titre : Guide pratique efficace pour la conversion de l'encodage de langue Go Dans le développement quotidien de logiciels, nous rencontrons souvent le besoin de convertir du texte dans différents encodages. En tant que langage de programmation efficace et moderne, le langage Go fournit une riche bibliothèque standard et des fonctions intégrées, ce qui rend très simple et efficace la mise en œuvre de la conversion d'encodage de texte. Cet article présentera des directives pratiques sur la manière d'effectuer une conversion d'encodage dans le langage Go et fournira des exemples de code spécifiques. 1.Encodage UTF-8 et conversion de chaînes Dans le langage Go, les chaînes utilisent l'encodage UTF-8 par défaut

L'ère de l'IA de JS est arrivée ! L'ère de l'IA de JS est arrivée ! Apr 08, 2024 am 09:10 AM

Introduction à JS-Torch JS-Torch est une bibliothèque JavaScript d'apprentissage en profondeur dont la syntaxe est très similaire à celle de PyTorch. Il contient un objet tensoriel entièrement fonctionnel (peut être utilisé avec des dégradés suivis), des couches et des fonctions d'apprentissage en profondeur et un moteur de différenciation automatique. JS-Torch convient à la recherche sur l'apprentissage profond en JavaScript et fournit de nombreux outils et fonctions pratiques pour accélérer le développement de l'apprentissage profond. Image PyTorch est un framework d'apprentissage profond open source développé et maintenu par l'équipe de recherche de Meta. Il fournit un riche ensemble d'outils et de bibliothèques pour créer et former des modèles de réseaux neuronaux. PyTorch est conçu pour être simple, flexible et facile à utiliser, et ses fonctionnalités de graphique de calcul dynamique font

Compréhension approfondie des fonctions et caractéristiques du langage Go Compréhension approfondie des fonctions et caractéristiques du langage Go Mar 21, 2024 pm 05:42 PM

Fonctions et caractéristiques du langage Go Le langage Go, également connu sous le nom de Golang, est un langage de programmation open source développé par Google. Il a été initialement conçu pour améliorer l'efficacité et la maintenabilité de la programmation. Depuis sa naissance, le langage Go a montré son charme unique dans le domaine de la programmation et a reçu une large attention et reconnaissance. Cet article approfondira les fonctions et caractéristiques du langage Go et démontrera sa puissance à travers des exemples de code spécifiques. Prise en charge native de la concurrence Le langage Go prend automatiquement en charge la programmation simultanée, qui est implémentée via les mécanismes goroutine et canal.

See all articles