字符串的replace方法應(yīng)用淺析
更新時(shí)間:2011年12月06日 22:24:15 作者:
按照W3C的說明,String對(duì)象的replace方法調(diào)用方式是stringObject.replace(regexp/substr,replacement)。
這兩個(gè)參數(shù)都是必須的,replace() 方法的參數(shù) replacement 可以是函數(shù)而不是字符串。在這種情況下,每個(gè)匹配都調(diào)用該函數(shù),它返回的字符串將作為替換文本使用。該函數(shù)的第一個(gè)參數(shù)是匹配模式的字符串。接下來的參數(shù)是與模式中的子表達(dá)式匹配的字符串,可以有 0 個(gè)或多個(gè)這樣的參數(shù)。接下來的參數(shù)是一個(gè)整數(shù),聲明了匹配在 stringObject 中出現(xiàn)的位置。最后一個(gè)參數(shù)是 stringObject 本身。對(duì)于replacement是函數(shù)的情況,給我們提供了很大的便利。
這有一個(gè)很簡(jiǎn)單的交換兩個(gè)單詞順序的例子,如果不用repalce可以這么做:
(function(){
var str = 'click dblclick';
var result = str.split(/\b/).reverse().join('')
console.log(result);
})()
這么做略顯麻煩,用replace處理則顯得清爽許多:
(function(){
var str = 'click dblclick';
var result = str.replace(/\b(\w+)(\s+)(\w+)\b/,'$3$2$1');
console.log(result);
})();
再看另一個(gè)例子——給數(shù)字加上千分位:
(function(){
var number = 12345678900;
var result = (''+number).replace(/(\d)(?=(\d{3})+$)/g,'$1,');
console.log(result);
})();
不過現(xiàn)在要扯的是replacement作為函數(shù)的用法,所以多此一舉的把上面的形式改成函數(shù)的形式:
(function(){
var str = 'click dblclick';
var result = str.replace(/\b(\w+)(\s+)(\w+)\b/,function(all,$1,$2,$3){
return $3+$2+$1;
});
console.log(result);
})();
(function(){
var number = 12345678900;
var result = (''+number).replace(/(\d)(?=(\d{3})+$)/g,function(all,$1){
return $1 + ',';
});
console.log(result);
})();
所以replace無非是捕獲匹配的項(xiàng)然后經(jīng)過處理,作為返回值進(jìn)行替換,只不過是函數(shù)的比較給力。
下面看一個(gè)比較實(shí)用的例子,大多數(shù)語言都有的格式化輸出,比如C語言的printf:
(function(){
var str = '%s may have gone, but there is a time of %s';
var result = str.replace(/(%s)/g,function(){
return 'replacement';
})
console.log(result);
})()
這里有個(gè)問題就是,%s都是一樣的,替換出來都是一樣的,而且我們只能按照順序來判斷被替換的是哪一部分,如果添加一段,那么后面所有的都得變。所以我們得傳個(gè)變量進(jìn)去。
(function(){
var array = ['Swallows','return'];
var i = 0;
var str = '%s may have gone, but there is a time of %s';
var result = str.replace(/(%s)/g,function(){
return array[i++];
})
console.log(result);
})();
(function(){
var str = '#{what} may have gone, but there is a time of #{how}';
var obj = {
what : 'Swallows',
how : 'return'
}
var result = str.replace(/(?:#{(\w+)})/g,function(all,$1){
return obj[$1];
})
console.log( result);
})();
顯然用對(duì)象的方法要靠譜一點(diǎn)。
同時(shí),js并沒有那么嚴(yán)格的類型要求,所以,%s這種形式也成為了局限。直接擯棄,換成我們?nèi)菀桌斫獾男问健?
偽裝成函數(shù)的樣子就是:
(function(){
function gsub(str,replaceObj){
return str.replace(/(?:#{(\w+)})/g,function(all,$1){
return replaceObj[$1];
})
}
console.log('gsub結(jié)果:',gsub('#{what} may have gone, but there is a time of #{how}',{
what : 'Swallows',
how : 'return'
}))
})();
上面的gsub借用了Prototype中的gsub方法名字,雖然Prototype中的gsub并不是用的replace,但是形式上還是很像的。
現(xiàn)在面臨的一個(gè)問題是:
#{what}這種形式的沖突問題,有可能字符串里面剛好就有這種形式的字符串,如果不作處理,后果大家都懂的。
第一種解決辦法:正則里面有轉(zhuǎn)義字符,我們也可以有,所以我們干脆在不需要的替換的部分前面加上'\'
第二種解決辦法:讓使用者自定義一個(gè)標(biāo)志來替換#{}的標(biāo)志,從而避免沖突。
看第一種方法:
(function(){
var str = '#{what} may have gone, but there is a time of #{how},\\#{reserve}';
function gsub(str,replaceObj){
return str.replace(/(^|.)(?:#{(\w+)})/g,function(all,$1,$2){
if($1 == '\\'){
return '#{' + $2 +'}';
}
return $1 + replaceObj[$2];
})
}
console.log('gsub結(jié)果:',gsub(str,{
what : 'Swallows',
how : 'return'
}))
})();
上面需要注意的就是'\'在字符串中也是轉(zhuǎn)義字符,寫的時(shí)候也需要轉(zhuǎn)義。
第二種方法:
我們把'#{what}'換成<%what%>的形式。
(function(){
function gsub(str,replaceObj,regexp){
regexp = regexp || /(?:#{(\w+)})/g;
return str.replace(regexp,function(all,$1){
return replaceObj[$1];
})
}
var str = '<%what%> may have gone, but there is a time of <%how%>,#{reserve}';
console.log('gsub結(jié)果:',gsub(str,{
what : 'Swallows',
how : 'return'
},/(?:<%(\w+)%>)/g))
})();
現(xiàn)在把gsub掛到String的原型上面
String.prototype.gsub = function(replaceObj,regexp){
regexp = regexp || /(^|.)(?:(#{)(\w+)(}))/g;
return this.replace(regexp,function(all,$1,$2,$3,$4){
if($1 == '\\'){
return $2+$3+$4;
}
return $1 + replaceObj[$3] ;
})
}
var str = '<%what%> may have gone, but there is a time of <%how%>,\\<%how%>,#{how}';
var obj = {
what : 'Swallows',
how : 'return'
}
console.log('測(cè)試1:',str.gsub(obj,/(^|.)(?:(<%)(\w+)(%>))/g));
//Swallows may have gone, but there is a time of return,<%how%>,#{how}
console.log('測(cè)試2:',str.gsub(obj));
//<%what%> may have gone, but there is a time of <%how%>,\<%how%>,return
嘿嘿,貌似和Prototype中的gsub很像了,不過Prototype中的gsub復(fù)雜一些,原理也不一致,熟悉一下,待會(huì)再仔細(xì)分析Prototype中的gsub方法。
這有一個(gè)很簡(jiǎn)單的交換兩個(gè)單詞順序的例子,如果不用repalce可以這么做:
復(fù)制代碼 代碼如下:
(function(){
var str = 'click dblclick';
var result = str.split(/\b/).reverse().join('')
console.log(result);
})()
這么做略顯麻煩,用replace處理則顯得清爽許多:
復(fù)制代碼 代碼如下:
(function(){
var str = 'click dblclick';
var result = str.replace(/\b(\w+)(\s+)(\w+)\b/,'$3$2$1');
console.log(result);
})();
再看另一個(gè)例子——給數(shù)字加上千分位:
復(fù)制代碼 代碼如下:
(function(){
var number = 12345678900;
var result = (''+number).replace(/(\d)(?=(\d{3})+$)/g,'$1,');
console.log(result);
})();
不過現(xiàn)在要扯的是replacement作為函數(shù)的用法,所以多此一舉的把上面的形式改成函數(shù)的形式:
復(fù)制代碼 代碼如下:
(function(){
var str = 'click dblclick';
var result = str.replace(/\b(\w+)(\s+)(\w+)\b/,function(all,$1,$2,$3){
return $3+$2+$1;
});
console.log(result);
})();
(function(){
var number = 12345678900;
var result = (''+number).replace(/(\d)(?=(\d{3})+$)/g,function(all,$1){
return $1 + ',';
});
console.log(result);
})();
所以replace無非是捕獲匹配的項(xiàng)然后經(jīng)過處理,作為返回值進(jìn)行替換,只不過是函數(shù)的比較給力。
下面看一個(gè)比較實(shí)用的例子,大多數(shù)語言都有的格式化輸出,比如C語言的printf:
復(fù)制代碼 代碼如下:
(function(){
var str = '%s may have gone, but there is a time of %s';
var result = str.replace(/(%s)/g,function(){
return 'replacement';
})
console.log(result);
})()
這里有個(gè)問題就是,%s都是一樣的,替換出來都是一樣的,而且我們只能按照順序來判斷被替換的是哪一部分,如果添加一段,那么后面所有的都得變。所以我們得傳個(gè)變量進(jìn)去。
復(fù)制代碼 代碼如下:
(function(){
var array = ['Swallows','return'];
var i = 0;
var str = '%s may have gone, but there is a time of %s';
var result = str.replace(/(%s)/g,function(){
return array[i++];
})
console.log(result);
})();
(function(){
var str = '#{what} may have gone, but there is a time of #{how}';
var obj = {
what : 'Swallows',
how : 'return'
}
var result = str.replace(/(?:#{(\w+)})/g,function(all,$1){
return obj[$1];
})
console.log( result);
})();
顯然用對(duì)象的方法要靠譜一點(diǎn)。
同時(shí),js并沒有那么嚴(yán)格的類型要求,所以,%s這種形式也成為了局限。直接擯棄,換成我們?nèi)菀桌斫獾男问健?
偽裝成函數(shù)的樣子就是:
復(fù)制代碼 代碼如下:
(function(){
function gsub(str,replaceObj){
return str.replace(/(?:#{(\w+)})/g,function(all,$1){
return replaceObj[$1];
})
}
console.log('gsub結(jié)果:',gsub('#{what} may have gone, but there is a time of #{how}',{
what : 'Swallows',
how : 'return'
}))
})();
上面的gsub借用了Prototype中的gsub方法名字,雖然Prototype中的gsub并不是用的replace,但是形式上還是很像的。
現(xiàn)在面臨的一個(gè)問題是:
#{what}這種形式的沖突問題,有可能字符串里面剛好就有這種形式的字符串,如果不作處理,后果大家都懂的。
第一種解決辦法:正則里面有轉(zhuǎn)義字符,我們也可以有,所以我們干脆在不需要的替換的部分前面加上'\'
第二種解決辦法:讓使用者自定義一個(gè)標(biāo)志來替換#{}的標(biāo)志,從而避免沖突。
看第一種方法:
復(fù)制代碼 代碼如下:
(function(){
var str = '#{what} may have gone, but there is a time of #{how},\\#{reserve}';
function gsub(str,replaceObj){
return str.replace(/(^|.)(?:#{(\w+)})/g,function(all,$1,$2){
if($1 == '\\'){
return '#{' + $2 +'}';
}
return $1 + replaceObj[$2];
})
}
console.log('gsub結(jié)果:',gsub(str,{
what : 'Swallows',
how : 'return'
}))
})();
上面需要注意的就是'\'在字符串中也是轉(zhuǎn)義字符,寫的時(shí)候也需要轉(zhuǎn)義。
第二種方法:
我們把'#{what}'換成<%what%>的形式。
復(fù)制代碼 代碼如下:
(function(){
function gsub(str,replaceObj,regexp){
regexp = regexp || /(?:#{(\w+)})/g;
return str.replace(regexp,function(all,$1){
return replaceObj[$1];
})
}
var str = '<%what%> may have gone, but there is a time of <%how%>,#{reserve}';
console.log('gsub結(jié)果:',gsub(str,{
what : 'Swallows',
how : 'return'
},/(?:<%(\w+)%>)/g))
})();
現(xiàn)在把gsub掛到String的原型上面
復(fù)制代碼 代碼如下:
String.prototype.gsub = function(replaceObj,regexp){
regexp = regexp || /(^|.)(?:(#{)(\w+)(}))/g;
return this.replace(regexp,function(all,$1,$2,$3,$4){
if($1 == '\\'){
return $2+$3+$4;
}
return $1 + replaceObj[$3] ;
})
}
var str = '<%what%> may have gone, but there is a time of <%how%>,\\<%how%>,#{how}';
var obj = {
what : 'Swallows',
how : 'return'
}
console.log('測(cè)試1:',str.gsub(obj,/(^|.)(?:(<%)(\w+)(%>))/g));
//Swallows may have gone, but there is a time of return,<%how%>,#{how}
console.log('測(cè)試2:',str.gsub(obj));
//<%what%> may have gone, but there is a time of <%how%>,\<%how%>,return
嘿嘿,貌似和Prototype中的gsub很像了,不過Prototype中的gsub復(fù)雜一些,原理也不一致,熟悉一下,待會(huì)再仔細(xì)分析Prototype中的gsub方法。
您可能感興趣的文章:
- js正則表達(dá)式之replace函數(shù)用法
- replace MYSQL字符替換函數(shù)sql語句分享(正則判斷)
- javascript筆記 String類replace函數(shù)的一些事
- js中字符替換函數(shù)String.replace()使用技巧
- js中關(guān)于String對(duì)象的replace使用詳解
- javascript中基于replace函數(shù)的正則表達(dá)式語法
- JavaScript中使用replace結(jié)合正則實(shí)現(xiàn)replaceAll的效果
- javascript 正則替換 replace(regExp, function)用法
- js replace() 文本替換你所不知的
- JavaScript replace(rgExp,fn)正則替換的用法
- javascript replace()正則替換實(shí)現(xiàn)代碼
- JS的replace方法介紹
相關(guān)文章
微信小程序?qū)崿F(xiàn)簡(jiǎn)單計(jì)算器與秒表
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)簡(jiǎn)單計(jì)算器與秒表,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-09-09
原生JS實(shí)現(xiàn)簡(jiǎn)單放大鏡效果
這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)簡(jiǎn)單放大鏡效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02
js實(shí)現(xiàn)圖片上傳到服務(wù)器和回顯
這篇文章主要介紹了js實(shí)現(xiàn)圖片上傳到服務(wù)器和回顯,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01
Javascript動(dòng)態(tài)綁定事件的簡(jiǎn)單實(shí)現(xiàn)代碼
Javascript事件綁定的方法很多,很靈活。不過,作為比較簡(jiǎn)單的動(dòng)態(tài)綁定,下面的代碼看似正確,但得不到預(yù)期的效果。2010-12-12
javascript generator生成器函數(shù)與asnyc/await語法糖
本文主要介紹了javascript generator生成器函數(shù)與asnyc/await語法糖,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-03-03
JavaScript高級(jí)程序設(shè)計(jì) DOM學(xué)習(xí)筆記
DOM是針對(duì)XML和HTML文檔的一個(gè)API:即規(guī)定了實(shí)現(xiàn)文本節(jié)點(diǎn)操控的屬性、方法,具體實(shí)現(xiàn)由各自瀏覽器實(shí)現(xiàn)。2011-09-09
javascript算法學(xué)習(xí)(直接插入排序)
假設(shè)待排序的記錄存放在數(shù)組R[1..n]中。初始時(shí),R[1]自成1個(gè)有序區(qū),無序區(qū)為R[2..n]。從i=2起直至i=n為止,依次將R[i]插入當(dāng)前的有序區(qū)R[1..i-1]中,生成含n個(gè)記錄的有序區(qū)。2011-04-04
JS實(shí)現(xiàn)簡(jiǎn)單加減購(gòu)物車效果
這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡(jiǎn)單加減購(gòu)物車效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08

