RegExp 對象有 3 個方法:test()、exec() 以及 compile()。
1.test()
test() 方法檢索字符串中的指定值。返回值是 true 或 false。
var patt1=new RegExp("e");
document.write(patt1.test("The best things in life are free")); // true
2.exec()
exec() 方法檢索字符串中的指定值,返回找到的值,并確定其位置。
該函數返回一個數組,其中存放匹配的結果。如果未找到匹配,則返回值為 null。
var patt1=new RegExp("e");
document.write(patt1.test("The best things in life are free")); // e
3.compile()
函數用于更改正則表達式模式,并將正則表達式模式編譯為內部格式,從而執行得更快。
var str = "abc12456def45646ghi";
var regExp = new RegExp("[a-z]+");
document.writeln( regExp.exec(str) ); // abc
// 更改regExp的正則表達式模式,并進行編譯
// 這與下列語句的作用是相同的:regExp = /\d+/;
regExp.compile("\\d+");
document.writeln( regExp.exec(str) ); // 12456
4.global
您可以向 RegExp 對象添加第二個參數,以設定檢索。例如,如果需要找到所有某個字符的所有存在,則可以使用 "g" 參數 ("global")。
var patt1=new RegExp("e","g");
do
{
result=patt1.exec("The best things in life are free");
document.write(result);
}
while (result!=null)
//由于這個字符串中 6 個 "e" 字母,代碼的輸出將是:eeeeeenull
eg: 將content中所有的 0是不固定的,替換成images數組中對應圖片。
var content = res.content;
var images = res.imgs;
var reg_img = /<!--IMG#\d{1,9}-->/g ;
var result;
var num = 0;
while ((result = reg_img.exec(content)) != null) {
// console.log(reg_img.lastIndex);
// console.log(result[0]);
content = content.replace(new RegExp(result[0]), "<im
g src='"+images[num].src+"'/>");
num++;
}
5.相關知識:支持正則表達式的 String 對象的方法
search: 檢索與正則表達式相匹配的值。
var str="Visit W3School!"
document.write(str.search(/W3School/))
//6 返回第一次匹配到的位置-
match: 找到一個或多個正則表達式的匹配。
var str="1 plus 2 equal 3" console.log(str.match(/\d+/g)); //[1,2,3];
match返回值
- replace: 替換與正則表達式匹配的子串。
stringObject.replace(regexp/substr,replacement)- regexp/substr: 必需。規定子字符串或要替換的模式的 RegExp 對象。請注意,如果該值是一個字符串,則將它作為要檢索的直接量文本模式,而不是首先被轉換為 RegExp 對象
- replacement:必需。一個字符串值。規定了替換文本或生成替換文本的函數。
var str="Visit Microsoft!"
console.log(str.replace(/Microsoft/, "W3School"))
// Visit W3School!
//(/Microsoft/g 全局替換
//(/Microsoft/i 不區分大小寫替換
//在本例中,我們將把字符串中所有單詞的首字母都轉換為大寫:
var name = 'aaa bbb ccc';
uw=name.replace(/\b\w+\b/g, function(word){
return word.substring(0,1).toUpperCase()+word.substring(1);
});
// "Aaa Bbb Ccc"
- split: 把字符串分割為字符串數組,很常用。
js截取兩個字符串之間的內容:
var str = "aaabbbcccdddeeefff";
str = str.match(/aaa(\S*)fff/)[1];
alert(str);//結果bbbcccdddeee
var str = "aaab<h2>bbcccddde</h2>eefff";
str = str.match(/<h2>(\S*)<\/h2>/)[1]; //bbcccddde