Replace中的正則表達式
replace:把原有的字符替換成新的字符
1. replace的字符串替換
var str = 'pku2016pku2017'; str = str.replace('pku', 'pkusoft'); console.log(str); // pkusoft2016pku2017
在不使用正則的情況下,每次執(zhí)行只能替換一個字符,每次執(zhí)行都是從0開始替換,有重復的,無法全部替換
2. replace的正則的替換
str = str.replace(/pku/g, 'pkusoft'); // 使用正則的全局匹配 console.log(str); // pkusoftsoft2016pkusoft2017
首先和exec捕獲一樣,把所有和我們匹配正則的都捕獲到,然后把捕獲的內(nèi)容替換成我們需要替換的新內(nèi)容。
/pku/g按照這個正則把str中所有可以匹配的都捕獲到,然后統(tǒng)一都替換成'pkusoft'
replace第二個參數(shù)若是一個函數(shù)
1. 匿名函數(shù)執(zhí)行多少次,取決于正則能在字符串中捕獲多少次
2. 每次執(zhí)行匿名函數(shù),arguments值和通過exec捕獲到的內(nèi)容很類似
3. return 返回值就是需要去替換的內(nèi)容
str = str.replace(/pku/g, function () { console.log(arguments); // 第一次執(zhí)行: ["pku", 0, "pku2016pku2017"] // 第一次執(zhí)行: ["pku", 7, "pku2016pku2017"] // 返回的數(shù)組和執(zhí)行exec返回的結(jié)果一致 return 'pkusoft'; }); console.log(str); // pkusoftsoft2016pkusoft2017
replace的分組捕獲
str = str.replace(/(\d+)/g, function () { // console.log(arguments); // 第一次執(zhí)行: ["2016", "2016", 7, "pkusoft2016pkusoft2017"] // 第一次執(zhí)行: ["2017", "2017", 18, "pkusoft2016pkusoft2017"] // 返回的數(shù)組和執(zhí)行exec返回的結(jié)果一致 return '0000'; }); console.log(str); // pkusoft0000pkusoft0000
replace的應用
var str = '20171001'; var arr = ["零","壹","貳","叁","肆","伍","陸","柒","捌","玖"]; str = str.replace(/\d/g,function () { var num = arguments[0]; // 把捕獲的內(nèi)容,作為數(shù)組的下標 return arr[num]; }); console.log(str); // 貳零壹柒壹零零壹
總結(jié)
以上所述是小編給大家介紹的Replace中的正則表達式,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- 談談C# replace在正則表達式中的意義
- Freemaker Replace函數(shù)的正則表達式運用
- 詳解PHP正則表達式替換實現(xiàn)(PHP preg_replace,PHP preg_replace)
- javascript正則表達式使用replace()替換手機號的方法
- JS使用replace()方法和正則表達式進行字符串的搜索與替換實例
- 正則表達式中特殊符號及正則表達式的幾種方法總結(jié)(replace,test,search)
- JS、replace利用正則表達式替換SQL所有參數(shù)為指定格式的數(shù)據(jù)
- js replace正則表達式應用案例講解
- js正則表達式之replace函數(shù)用法
相關文章
- 正則表達式其實就是一個特殊的字符串,如果需要對字符串的內(nèi)容進行分析匹配,正則表達式是一個不錯的選擇。簡單的用String也能實現(xiàn)該過程,但是那會相當?shù)姆爆?/div> 2012-10-10
js正則表達式 限1-2位整數(shù),或者至多含有兩位小數(shù)的寫法
這篇文章主要介紹了js正則表達式,限1-2位整數(shù),或者至多含有兩位小數(shù),需要的朋友可以參考下2020-06-06最新評論