RegExp クラスは
正規表現パターンを扱うクラスです。
正規表現パターンには perl 互換のパターンを指定することができます。
JavaScript の RegExp クラスににていますが、互換性は低いです。
コンストラクタの構文は以下の通りです。
new RegExp(<パターン文字列>, <フラグ文字列=''>);
パターン文字列は正規表現パターンです。パターン中に指定する \ は、文字列即値中で書くときは \\ と書くことに注意してください。
フラグ文字列は g i の文字の組み合わせです。
g はグローバルサーチフラグです。このフラグをつけると、match、exec、replace の各メソッドで、パターンにマッチした文字列の部分すべてに対して処理が行われます。
i フラグは英字の大文字/小文字の区別を行いません。
例:
var re = new RegExp("[a-z]+[0-9]*", "gi");
var re = new RegExp("\\.\\.\\.");
/ と / で囲まれた部分に正規表現パターンを指定することができます。
トークン を参照してください。
compile メソッドは、正規表現オブジェクトに新しい正規表現パターンを設定します。
引数は RegExp クラスのコンストラクタに指定するものと同一です。
test メソッドは、引数に指定した文字列がパターンにマッチするかどうかを返します。
構文 : test(<文字列>)
パターンにマッチすれば真、マッチしなければ偽が返ります。
このメソッドはこのオブジェクトの各プロパティの値を更新します。
exec メソッドは、引数に指定した文字列に正規表現パターンマッチングを行い、マッチした結果を含む配列を返します。
構文 : exec(<文字列>)
パターンにマッチしない場合、配列の要素数は 0 になります。
マッチした場合、要素 0 (最初の要素) はマッチした部分全体、それ以降の要素は各マッチ部分 ( 正規表現パターン中の ( ) で指定した部分 ) が入っています。
このメソッドはこのオブジェクトの各プロパティの値を更新します。
match メソッドは、このオブジェクトのプロパティの値を更新しない以外は、exec メソッドと同一です。
構文 : match(<文字列>)
replace メソッドは、文字列の置き換えを行い、置き換えが行われた後の文字列を返します。
構文 : replace(<対象文字列>, <置き換え文字列>)
対象文字列に対してマッチングを行い、マッチした部分を置き換え文字列で置き換え、置き換えが行われた後の文字列を返します。
置き換え文字列として、文字列ではなく関数を渡すと、置き換え動作のためにその関数が呼ばれるようになります。関数は引数をひとつとり、対象文字列の中のマッチした部分をあらわす配列オブジェクトが渡されます ( この配列については exec メソッドを参照してください )。対象文字列中のマッチした部分は、関数の戻した文字列に置き換わります。
このメソッドは start プロパティを無視します。
split メソッドは、文字列を分割します。
構文 : split(<対象文字列>, <(予約)>, <空の要素を無視するか=false>)
文字列を分割した結果が格納された配列オブジェクトを返します。
Array クラス の split メソッドも参照してください。
matches プロパティは、マッチした各部分を含む配列を表す読み出し専用のプロパティです。
パターンにマッチしない場合、配列の要素数は 0 になります。
マッチした場合、要素 0 (最初の要素) はマッチした部分全体、それ以降の要素は各マッチ部分 ( 正規表現パターン中の ( ) で指定した部分 ) が入っています。
文字列の検索開始位置を表すプロパティです。値を設定することもできます。
マッチした部分の先頭文字の位置を表す、読み出し専用のプロパティです。0 が先頭を表すので、それがマッチング対象文字列の先頭の文字ならば 0 になります。
マッチした部分の最終文字の次の文字の位置を表す、読み出し専用のプロパティです。0 が先頭を表します。
マッチング対象の文字列をあらわす、読み出し専用のプロパティです。
マッチング対象文字列のうち、マッチした部分よりも左側の文字列をあらわす、読み出し専用のプロパティです。
マッチング対象文字列のうち、マッチした部分よりも右側の文字列をあらわす、読み出し専用のプロパティです。
マッチング対象文字列を表します。matches[0] と同じです。
マッチした各部分のうち、最後の部分を返します。matches[matches.count-1] と同じです。
最後に test あるいは exec メソッドが実行された RegExp クラスのインスタンスです。
例 : if(/pat(\d+)/.test(target)) { return RegExp.last.matches[1]; }
正規表現機能の実装には K.Kosako 氏の鬼車を用いています。有用なライブラリを公開なさっている氏に感謝します。