Heim Web-Frontend js-Tutorial Erweiterte Kenntnisse in der Verwendung von Split- und Join-Funktionen in JavaScript_Javascript-Kenntnisse

Erweiterte Kenntnisse in der Verwendung von Split- und Join-Funktionen in JavaScript_Javascript-Kenntnisse

May 16, 2016 pm 03:02 PM
javascript join js split 字符串 数组

Javascript verfügt über zwei sehr leistungsstarke Funktionen, die von Entwicklern geliebt werden: Split und Join, zwei gegensätzliche Funktionen. Diese beiden Funktionen ermöglichen den Austausch von String- und Array-Typen, d. h. Arrays können in Strings serialisiert werden und umgekehrt. Wir können diese beiden Funktionen voll ausnutzen. Lassen Sie uns einige interessante Anwendungen im Inneren erkunden. Lassen Sie uns zunächst diese beiden Funktionen vorstellen:

String.prototype.split(separator, limit)
Trennzeichen teilt die Zeichenfolge in Arrays auf und der optionale Parameter limit definiert die maximale Länge des generierten Arrays.

"85@@86@@53".split('@@'); //['85','86','53'];
"banana".split(); //["banana"]; //( thanks peter (-: )
"president,senate,house".split(',',2); //["president", "senate"]
Array.prototype.join(separator)
Nach dem Login kopieren

Der optionale Parameter Separator wandelt das Array in einen String um. Wenn kein Trennzeichen angegeben wird, wird ein Komma als Parameterwert verwendet (genau wie die toString-Funktion des Arrays).

["slugs","snails","puppy dog's tails"].join(' and '); //"slugs and snails and puppy dog's tails"
['Giants', 4, 'Rangers', 1].join(' '); //"Giants 4 Rangers 1"
[1962,1989,2002,2010].join();
Nach dem Login kopieren

Werfen wir einen Blick auf diese Apps:

alle ersetzen
Diese einfache Funktion kann im Gegensatz zur nativen Ersetzungsfunktion als globaler Teilstring-Ersatz ohne Verwendung regulärer Ausdrücke verwendet werden.

String.prototype.replaceAll = function(find, replaceWith) {
  return this.split(find).join(replaceWith); 
}

"the man and the plan".replaceAll('the','a'); //"a man and a plan"

Nach dem Login kopieren

Bei kleinen Zeichenfolgen ist die Leistung schwächer als bei der nativen Funktion zum Ersetzen einzelner Zeichen (hier sind die beiden zusätzlichen Funktionen regulärer Ausdrücke gemeint). Unter Mozilla wird diese Funktion jedoch schneller ausgeführt, wenn dieses Zeichen 2 oder 3 Zeichen überschreitet reguläre Ausdrücke.

Vorkommen
Diese Funktion kann die Anzahl der Teilstring-Übereinstimmungen ermitteln. Und diese Art von Funktion ist sehr einfach und erfordert keine Regularisierung.

String.prototype.occurences = function(find, matchCase) {
  var text = this;
  matchCase || (find = find.toLowerCase(), text = text.toLowerCase());
  return text.split(find).length-1;  
}

document.body.innerHTML.occurences("div"); //google home page has 114
document.body.innerHTML.occurences("/div"); //google home page has 57
"England engages its engineers".occurrences("eng",true); //2
repeat

Nach dem Login kopieren

Diese Funktion ist von Prototype.js entlehnt:

String.prototype.repeat = function(times) {
  return new Array(times+1).join(this);  
}

"go ".repeat(3) + "Giants!"; //"go go go Giants!"

Nach dem Login kopieren

Das Schöne daran liegt in der Verwendung der Join-Funktion. Der Fokus liegt auf dem Trennparameterwert und das zugrunde liegende Array enthält nur einige undefinierte Werte. Um diesen Punkt deutlicher zu veranschaulichen, erstellen wir das obige Beispiel nach:

[undefined,undefined,undefined,undefined].join("go ") + "Giants
Nach dem Login kopieren

Denken Sie daran, dass jedes Array-Element vor dem Zusammenfügen in einen String (in diesem Fall einen leeren String) konvertiert wird. Diese Anwendung der Wiederholungsfunktion ist eine der wenigen Anwendungen, bei denen die Definition eines Arrays über ein Array-Literal nicht möglich ist.

Grenzparameter verwenden
Ich verwende den optionalen Parameter „Limit“ der Split-Funktion selten. Hier ist ein Beispiel für die Verwendung dieses Limits:

var getDomain = function(url) {
  return url.split('/',3).join('/');
}

getDomain("http://www.aneventapart.com/2010/seattle/slides/");
//"http://www.aneventapart.com"
getDomain("https://addons.mozilla.org/en-US/firefox/bookmarks/");
//"https://addons.mozilla.org"

Nach dem Login kopieren

Zahlliche Elemente ändern
Wenn wir reguläre Ausdrücke mischen, verbinden und teilen, können wir die Array-Mitglieder leicht ändern. Aber diese Funktion ist nicht so schwierig wie gedacht. Ihre Hauptfunktion besteht darin, die vor jedem Mitglied des angegebenen Arrays angegebene Zeichenfolge zu entfernen.

var beheadMembers = function(arr, removeStr) {
  var regex = RegExp("[,]?" + removeStr);
  return arr.join().split(regex).slice(1);
}

//make an array containing only the numeric portion of flight numbers
beheadMembers(["ba015","ba129","ba130"],"ba"); //["015","129","130"]

Nach dem Login kopieren

Leider funktioniert diese Funktion im IE nicht, da dort fälschlicherweise das erste leere Mitglied aus der Aufteilung entfernt wird. Jetzt reparieren wir diese Funktion:

var beheadMembers = function(arr, removeStr) {
  var regex = RegExp("[,]?" + removeStr);
  var result = arr.join().split(regex);
  return result[0] && result || result.slice(1); //IE workaround
}
Nach dem Login kopieren

Warum sollten wir diese Technik anstelle der Kartenfunktion des Arrays in Emascript 5 verwenden?

["ba015","ba129","ba130"].map(function(e) {
  return e.replace('ba','')
}); //["015","129","130"] 
Nach dem Login kopieren

In tatsächlichen Anwendungen verwende ich, wenn möglich, normalerweise die native Kartenfunktion (nicht verfügbar in IE<9 und niedriger). Das folgende Beispiel dient nur als Lernhilfe, es ist jedoch zu beachten, dass die Aufrufsyntax von Join und Split einfacher und direkter ist. Das Interessanteste ist, dass es auch sehr effizient ist, insbesondere bei sehr kleinen Arrays, und in FF und Safari sogar noch effizienter. Für große Arrays ist die Kartenfunktion besser geeignet. (In allen Browsern) haben die Join- und Split-Funktionen weniger Funktionsaufrufe.

//test 1 - using join/split
var arr = [], x = 1000;
while (x--) {arr.push("ba" + x);}

var beheadMembers = function(arr, regex) {
  return arr.join().split(regex).slice(1);
}

var regex = RegExp("[,]&#63;" + 'ba');
var timer = +new Date, y = 1000;
while(y--) {beheadMembers(arr,regex);};
+new Date - timer;

//FF 3.6 733ms
//Ch 7  464ms
//Sa 5  701ms
//IE 8 1256ms

//test 2 - using native map function
var arr = [], x = 1000;
while (x--) {arr.push("ba" + x);}

var timer = +new Date, y = 1000;
while(y--) {
  arr.map(function(e) {
    return e.replace('ba','')
  });
}
+new Date - timer;

//FF 3.6 2051ms
//Cr 7  732ms
//Sf 5  1520ms
//IE 8  (Not supported)

Nach dem Login kopieren

Mustervergleich
Arrays müssen kontinuierlich einen Mustervergleich durchführen, Strings jedoch nicht. Reguläre Ausdrücke können für Zeichenfolgen verwendet werden, nicht jedoch für Arrays. Die Möglichkeiten, Arrays für den Mustervergleich in Strings umzuwandeln, gehen weit über den Rahmen dieses Artikels hinaus. Schauen wir uns eine einfache Anwendung davon an.

Angenommen, die Ergebnisse des Gehwettbewerbs müssen in einem Array gespeichert werden. Der Zweck besteht darin, die Teilnehmer mit ihren Rekordzeiten im Feld abzuwechseln. Wir können Joins und reguläre Ausdrücke verwenden, um zu überprüfen, ob dieser Speichermodus korrekt ist. Der folgende Code soll herausfinden, ob die Rekordzeit fehlt, indem nach zwei aufeinanderfolgenden Namen gesucht wird.

var results = ['sunil', '23:09', 'bob', '22:09', 'carlos', 'mary', '22:59'];
var badData = results.join(',').match(/[a-zA-Z]+,[a-zA-Z]+/g);
badData; //["carlos,mary"]
Nach dem Login kopieren

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie entferne ich doppelte Elemente mithilfe einer foreach-Schleife aus einem PHP-Array? Wie entferne ich doppelte Elemente mithilfe einer foreach-Schleife aus einem PHP-Array? Apr 27, 2024 am 11:33 AM

Die Methode zur Verwendung einer foreach-Schleife zum Entfernen doppelter Elemente aus einem PHP-Array ist wie folgt: Durchlaufen Sie das Array und löschen Sie es, wenn das Element bereits vorhanden ist und die aktuelle Position nicht das erste Vorkommen ist. Wenn beispielsweise in den Datenbankabfrageergebnissen doppelte Datensätze vorhanden sind, können Sie diese Methode verwenden, um diese zu entfernen und Ergebnisse ohne doppelte Datensätze zu erhalten.

Die Kunst des PHP Array Deep Copy: Mit verschiedenen Methoden eine perfekte Kopie erzielen Die Kunst des PHP Array Deep Copy: Mit verschiedenen Methoden eine perfekte Kopie erzielen May 01, 2024 pm 12:30 PM

Zu den Methoden zum tiefen Kopieren von Arrays in PHP gehören: JSON-Kodierung und -Dekodierung mit json_decode und json_encode. Verwenden Sie array_map und clone, um tiefe Kopien von Schlüsseln und Werten zu erstellen. Verwenden Sie Serialize und Deserialize für die Serialisierung und Deserialisierung.

PHP-Array-Schlüsselwertumdrehen: Vergleichende Leistungsanalyse verschiedener Methoden PHP-Array-Schlüsselwertumdrehen: Vergleichende Leistungsanalyse verschiedener Methoden May 03, 2024 pm 09:03 PM

Der Leistungsvergleich der PHP-Methoden zum Umdrehen von Array-Schlüsselwerten zeigt, dass die Funktion array_flip() in großen Arrays (mehr als 1 Million Elemente) eine bessere Leistung als die for-Schleife erbringt und weniger Zeit benötigt. Die for-Schleifenmethode zum manuellen Umdrehen von Schlüsselwerten dauert relativ lange.

Anwendung der PHP-Array-Gruppierungsfunktion bei der Datensortierung Anwendung der PHP-Array-Gruppierungsfunktion bei der Datensortierung May 04, 2024 pm 01:03 PM

Die PHP-Funktion array_group_by kann Elemente in einem Array basierend auf Schlüsseln oder Abschlussfunktionen gruppieren und ein assoziatives Array zurückgeben, wobei der Schlüssel der Gruppenname und der Wert ein Array von Elementen ist, die zur Gruppe gehören.

Best Practices für Deep Copying von PHP-Arrays: Entdecken Sie effiziente Methoden Best Practices für Deep Copying von PHP-Arrays: Entdecken Sie effiziente Methoden Apr 30, 2024 pm 03:42 PM

Die beste Vorgehensweise zum Durchführen einer Array-Deep-Kopie in PHP besteht darin, json_decode(json_encode($arr)) zu verwenden, um das Array in einen JSON-String zu konvertieren und ihn dann wieder in ein Array umzuwandeln. Verwenden Sie unserialize(serialize($arr)), um das Array in eine Zeichenfolge zu serialisieren und es dann in ein neues Array zu deserialisieren. Verwenden Sie den RecursiveIteratorIterator, um mehrdimensionale Arrays rekursiv zu durchlaufen.

Praxis der mehrdimensionalen Sortierung von PHP-Arrays: von einfachen bis hin zu komplexen Szenarien Praxis der mehrdimensionalen Sortierung von PHP-Arrays: von einfachen bis hin zu komplexen Szenarien Apr 29, 2024 pm 09:12 PM

Die mehrdimensionale Array-Sortierung kann in Einzelspaltensortierung und verschachtelte Sortierung unterteilt werden. Bei der Einzelspaltensortierung kann die Funktion array_multisort() zum Sortieren nach Spalten verwendet werden. Bei der verschachtelten Sortierung ist eine rekursive Funktion erforderlich, um das Array zu durchlaufen und zu sortieren. Zu den praktischen Beispielen gehören die Sortierung nach Produktname und die Sortierung von Verbindungen nach Verkaufsmenge und Preis.

PHP-Array-Zusammenführungs- und Deduplizierungsalgorithmus: parallele Lösung PHP-Array-Zusammenführungs- und Deduplizierungsalgorithmus: parallele Lösung Apr 18, 2024 pm 02:30 PM

Der PHP-Algorithmus zum Zusammenführen und Deduplizieren von Arrays bietet eine parallele Lösung, indem er das ursprüngliche Array zur parallelen Verarbeitung in kleine Blöcke aufteilt und der Hauptprozess die Ergebnisse der zu deduplizierenden Blöcke zusammenführt. Algorithmusschritte: Teilen Sie das ursprüngliche Array in gleichmäßig verteilte kleine Blöcke auf. Verarbeiten Sie jeden Block zur Deduplizierung parallel. Blockergebnisse zusammenführen und erneut deduplizieren.

Die Rolle der PHP-Array-Gruppierungsfunktion beim Auffinden doppelter Elemente Die Rolle der PHP-Array-Gruppierungsfunktion beim Auffinden doppelter Elemente May 05, 2024 am 09:21 AM

Mit der Funktion array_group() von PHP kann ein Array nach einem angegebenen Schlüssel gruppiert werden, um doppelte Elemente zu finden. Diese Funktion durchläuft die folgenden Schritte: Verwenden Sie key_callback, um den Gruppierungsschlüssel anzugeben. Verwenden Sie optional value_callback, um Gruppierungswerte zu bestimmen. Zählen Sie gruppierte Elemente und identifizieren Sie Duplikate. Daher ist die Funktion array_group() sehr nützlich, um doppelte Elemente zu finden und zu verarbeiten.

See all articles