1、JS字符串的替換及replace()方法的使用
replace(regexp,replacement)方法有兩個參數(shù),第一參數(shù)可以是一個純文本字符串或是一個RegExp對象,具體請看RegExp對象的使用;第二個參數(shù)可是一個字符串也可以是一個函數(shù)。
以下是JS字符串替換的舉例:
例1:
復(fù)制代碼 代碼如下:
var str="Hello world!";
document.write(str.replace(/world/, "phper"));
復(fù)制代碼 代碼如下:
var reg=new RegExp("(//w+),(//d+),(//w+)","gmi");
var info="Lili,14,China";
var rep=info.replace(reg, "She is $1, $2 years old, come from $3");
alert(rep);
復(fù)制代碼 代碼如下:
var reg=new RegExp("(//w+),(//d+),(//w+)","gmi");
var info="Lili,14,China";
var name, age, from;
function prase_info(m,p1,p2,p3) { // 也可使用非顯式參數(shù),使用arguments獲取
name = p1;
age = p2;
from = p3;
return "She is "+p1+", "+p2+" years old, come from "+p3;
}
var rep=info.replace(reg, prase_info);
alert(rep);
aler(name);
2、RegExp對象的使用
JavaScript提供了一個RegExp對象來完成有關(guān)正則表達(dá)式的操作和功能,每一條正則表達(dá)式模式對應(yīng)一個RegExp實例。有兩種方式可以創(chuàng)建RegExp對象的實例。
使用RegExp的顯式構(gòu)造函數(shù),語法為:new RegExp("pattern"[,"flags"]);使用RegExp的隱式構(gòu)造函數(shù),采用純文本格式:/pattern/[flags]。例4中兩條語句是等價的。
例4:
復(fù)制代碼 代碼如下:
var re1 = new RegExp("http://d{5}");
var re2 = //d{5}/;
exec()方法返回一個數(shù)組,其中存放匹配的結(jié)果。如果未找到匹配,則返回值為 null。
例5:
復(fù)制代碼 代碼如下:
var reg=new RegExp("(//w+),(//d+),(//w+)","gmi");
var m=reg.exec("Lili,14,China");
var s="";
for (i = 0; i < m.length; i++) {
s = s + m[i] + "/n";
}
alert(s);
RegExpObject.test(string)
如果字符串 string 中含有與 RegExpObject 匹配的文本,則返回 true,否則返回 false。
例6:
復(fù)制代碼 代碼如下:
var reg=new RegExp("(//w+),(//d+),(//w+)","gmi");
var m=reg.test("Lili,14,China");
alert(RegExp.$1);
alert(RegExp.$2);
alert(RegExp.$3);
新聞熱點
疑難解答
圖片精選