String對象中支持正則表達式有4種方法,分別是:search、replace、match、split
定義:search()方法將在字符串str中檢索與表達式regexp相匹配的字串,并且返回第一個匹配字串的第一個字符的位置。如果沒有找到任何匹配的字串,則返回-1。
例如:
var str = "Javascript";
str.search(/script/); // 返回 script 中s的位置為 4
str.search(/j/i); // 設置正則表達是標識i:忽略大小寫,則匹配到J,返回位置0
但是,search()方法不支持全局搜索,因為會忽略正則表達式參數(shù)的標識g,并且也忽略了regexp的lastIndex屬性,總是從字符串的開始位置進行檢索,所以它會總是返回str的第一個匹配的位置。
例如:
var str = "javascript is cool";
str.search(/s/g); // 返回 javascript 中的s位置4,不會繼續(xù)檢索s
定義:replace()方法是執(zhí)行查找并替換的操作。它將正則表達式regexp匹配到的字串,然后用replacement的字符串替換掉字串,如果有全局標識g,則替換全部匹配的字串,否則只替換第一個匹配字串。
replace方法應該是比較常用的一個方法,在字符串替換操作中非常有用的。例如:
1、簡單替換
var str = "javascript";
str.replace(/javascript/,'JavaScript'); // 將字符串javascript替換為JavaScript
2、全局替換
// 使用全局表示g進行全局替換
var str = "javascript";
str.replace(/a/g, 'b'); // 將所有的字母a替換為字母b,返回 jbvbscript
3、使用replacement中的特殊字符替換,在replacement中$字符有特殊的意義,具體說明如下表格:
字符 | 替換文本 |
---|---|
$1、$2、...、$99 | 與regexp中的第1個到99 個子表達式相匹配的文本 |
$& | 與regexp相匹配的字串 |
$` | 位于匹配子串左側(cè)的文本 |
$' | 位于匹配子串右側(cè)的文本 |
$$ | 直接量符號 |
來看下例子:
//1、用子表達式替換:$1、$2等
var str = "javascript";
str.replace(/(java)(script)/,'$2$1');
// 表達式中()就是一個子表達式,$1對應是第一個表達式的內(nèi)容,即java,$2為script,所以替換
4、使用replacement作為函數(shù)替換
replace的參數(shù)replacement可以是函數(shù)而不是字符串,每個匹配都會調(diào)用該函數(shù),它返回的字符串將作為替換的文本使用。該函數(shù)的第一個參數(shù)是整個匹配模式的字符串,接下來的參數(shù)是與模式中的子表達式匹配的字符串,可以有0個或多個參數(shù)。接下來的參數(shù)是一個整數(shù),聲明了匹配在str中出現(xiàn)的位置。最后的參數(shù)是str自身。
來看個例子:
// match 為匹配整個字符串,即:'abc12345#$*%'
// p1 為第一個子表達式,([^\d]*),匹配0個或多個非數(shù)字的字符,即:abc
// p2 為第二個子表達式,(\d*),匹配0個或多個的數(shù)字,即:12345
// p3 為第三個子表達式,([^\w]*),匹配0個或匹配任何非單詞字符。等價于 '[^A-Za-z0-9_]',即 #$*%
// offset 為模式匹配出現(xiàn)的位置,從第一個字符已經(jīng)匹配成功,則位置為0
// string為字符串本身,即 abc12345#$*%
function replacer(match, p1, p2, p3, offset, string) {
return [p1, p2, p3].join(' - ');
}
var newString = 'abc12345#$*%'.replace(/([^\d]*)(\d*)([^\w]*)/, replacer);
// 替換
定義:match()方法是最常用的String正則表達式方法。它唯一的參數(shù)就是一個正則表達式或者通過RegExp()構(gòu)造函數(shù)來創(chuàng)建正則表達式,返回值是包含了匹配結(jié)果的數(shù)組。
match()方法中的regexp正則表達式一般又分為兩種情況:有設置全局標志g和沒有設置全局標志
1、有設置全局標志
如果設置了全局標志g,則返回的數(shù)組包含的就是出現(xiàn)在字符串的所有匹配結(jié)果,例如:
// 全局匹配
var str = "1 plus 2 equals 3";
str.match(/\d/g); // 匹配字符串中出現(xiàn)的所有數(shù)字,并返回一個數(shù)組: [1,2,3]
2、沒有設置全局標志
如果沒有設置全局標志,則就不是全局性的檢索,只是檢索第一個匹配。這種情況下,match()方法匹配的結(jié)果也是返回一個數(shù)組,數(shù)組的第一個元素就是匹配的字符串,而余下的元素則是正則表達式中用括號括起來的子表達式。來看個例子:
// 非全局匹配
var str = "visit my blog at http://www.example.com";
str.match(/(\w+):\/\/([\w.]+)/); // 返回結(jié)果:["http://www.example.com", "http", "www.example.com"]
// 正則表達式匹配的
定義:split()方法可以把調(diào)用它的字符串分解為一個字串數(shù)組,使用的分隔符是它的參數(shù)。
參數(shù):
delimiter:字符串或者正則表達式,從該參數(shù)指定的地方分割字符串。
limit:指定返回數(shù)組的最大長度,如果沒有設置該參數(shù),則整個字符串都會被分割。
例如:
//1、 只傳一個參數(shù),默認分割整個字符串
var str ="a,b,c,d,e";
str.split(','); // 返回分割的字符串數(shù)組:["a", "b", "c", "d", "e"]
//2、傳入兩個參數(shù)
var str ="a,b,c,d,e";
str.split(',',3); //指定限定長度,則返回對應的數(shù)組:["a", "b", "c"]
//3、使用正則表達式匹配,不包含分割字符串
var str = "aa44bb55cc66dd";
str.split(/\d+/); //通過匹配數(shù)字進行分割字符串,但不包含分割的字符串,則返回的
關于正則表達式模式匹配的String方法的相關知識,小編就給大家介紹到這里。
聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com