JavaScript には、開発者に愛される 2 つの非常に強力な関数があります。それは、分割と結合という 2 つの相反する関数です。これら 2 つの関数を使用すると、文字列型と配列型を交換できます。つまり、配列を文字列にシリアル化したり、その逆を行うことができます。この2つの機能を使いこなすことができます。内部の興味深いアプリケーションをいくつか見てみましょう。まず、次の 2 つの関数を紹介します。
String.prototype.split(区切り文字, 制限)
区切り文字は文字列を配列に分割し、オプションのパラメータ制限は生成される配列の最大長を定義します。
"85@@86@@53".split('@@'); //['85','86','53']; "banana".split(); //["banana"]; //( thanks peter (-: ) "president,senate,house".split(',',2); //["president", "senate"] Array.prototype.join(separator)
["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();
すべて置き換え
この単純な関数は、ネイティブの置換関数とは異なり、正規表現を使用せずにグローバルな部分文字列置換として使用できます。
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"
出来事
この関数は部分文字列の一致の数を取得できます。そして、この種の関数は非常に単純で、正規化を必要としません。
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
String.prototype.repeat = function(times) { return new Array(times+1).join(this); } "go ".repeat(3) + "Giants!"; //"go go go Giants!"
[undefined,undefined,undefined,undefined].join("go ") + "Giants
制限パラメーターを使用
私は、split 関数のオプションパラメータであるlimitをほとんど使用しません。この制限の使用例を次に示します。
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"
数値メンバーを変更します
正規表現を組み合わせたり、結合、分割したりすると、配列のメンバーを簡単に変更できます。しかし、この関数は想像されているほど難しくはありません。その主な機能は、指定された配列の各メンバーの前に指定された文字列を削除することです。
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"]
var beheadMembers = function(arr, removeStr) { var regex = RegExp("[,]?" + removeStr); var result = arr.join().split(regex); return result[0] && result || result.slice(1); //IE workaround }
["ba015","ba129","ba130"].map(function(e) { return e.replace('ba','') }); //["015","129","130"]
//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("[,]?" + '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)
パターンマッチング
配列ではパターン マッチングを継続的に実行する必要がありますが、文字列ではその必要はありません。正規表現は文字列には使用できますが、配列には使用できません。パターン マッチングのために配列を文字列に変換する機能については、この記事の範囲をはるかに超えています。それの簡単な応用を見てみましょう。
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"]