js replace正則相關(guān)的詭異問題

測(cè)試的昵稱:jesse$<
查看代碼:Javascript代碼
$id("f_msg_grow_1").innerHTML=msg["not_club"]["grow_value"].replace(/\{NICK_NAME}/,this.info["friend"]["nick_name"]);
看代碼很快可以注意到兩點(diǎn):“replace 正則”和“$ ”。
在js 中replace 支持正則表達(dá)式,而$ 又恰好是正則向后匹配的特殊字符,很容易想到是正則引起的問題。而據(jù)我所知正則向后引用只有$1 、$2 、$3 、$4…… ,而這里只有一個(gè)”$” 沒有數(shù)字。
昵稱“jesse$< ”在后臺(tái)經(jīng)html 特殊字符處理,傳到前端是:“jesse$< ”,看頁面結(jié)果注意到“$” 后的“&” 的也被替換了。難道是“$&” 在js 里表示正則向后引用的全匹配?
然后去掉了正則,將代碼改成:Javascript代碼
$id("f_msg_grow_1").innerHTML=msg["not_club"]["grow_value"].replace("{NICK_NAME}",this.info["friend"]["nick_name"]);
居然還是同樣的結(jié)果,太詭異了!!!
更詭異的是在IE 下查看,居然是顯示正確的(之前一直在ff 下測(cè)試)!
測(cè)試代碼:Javascript代碼
document.write("姓名:{NAME}".replace(/\{NAME}/g,"張劍光$&"));
IE 和ff 顯示相同:C-sharp代碼
姓名:張劍光{NAME}amp;
經(jīng)測(cè)試,“$&” 果真表示正則向后引用的全匹配,算我孤陋,之前居然不知道!
測(cè)試代碼:Javascript代碼
document.write("姓名:{NAME}".replace("{NAME}","張劍光$&"));
ff 顯示:C-sharp代碼
姓名:張劍光{NAME}amp
IE 顯示:C-sharp代碼
姓名:張劍光$&
經(jīng)測(cè)試,ff 下居然replace 即使不用正則,“$&” 也表示向后全匹配?。。?
無語!
查找資料、測(cè)試并總結(jié)如下:
一、
字符 |
含義 |
$$ |
$ |
$& |
指定與整個(gè)模式匹配的 stringObj 的部分。 |
$` |
指定由 $& 描述的匹配之前的 stringObj 部分。 |
$' |
指定由 $& 描述的匹配之后的 stringObj 部分。 |
測(cè)試代碼:
document.write("姓名:{NAME}__".replace(/\{NAME}/g,"張劍光$&"));
document.write("姓名:{NAME}__".replace(/\{NAME}/g,"張劍光$$"));
document.write("姓名:{NAME}__".replace(/\{NAME}/g,"張劍光$`"));
document.write("姓名:{NAME}__".replace(/\{NAME}/g,"張劍光$'"));
Ie 、ff 和chrome 結(jié)果相同:
姓名:張劍光{NAME}amp__姓名:張劍光$__姓名:張劍光姓名:__姓名:張劍光____
二、 ff 和chrome 下replace 不使用正則,也對(duì)上述特殊字符起作用
ie 下replace 不使用正則,對(duì)上述特殊字符不起作用 測(cè)試代碼:
document.write("姓名:{NAME}__".replace("{NAME}","張劍光$&"));
document.write("姓名:{NAME}__".replace("{NAME}","張劍光$&"));
document.write("姓名:{NAME}__".replace("{NAME}","張劍光$$"));
document.write("姓名:{NAME}__".replace("{NAME}","張劍光$`"));
document.write("姓名:{NAME}__".replace("{NAME}","張劍光$'"));
ff 和chrome 結(jié)果:
姓名:張劍光{NAME}amp__姓名:張劍光$__姓名:張劍光姓名:__姓名:張劍光____
Ie 結(jié)果:
姓名:張劍光$&__姓名:張劍光$&__姓名:張劍光$$__姓名:張劍光$`__姓名:張劍光$'__
三、 由此,我們?cè)趹?yīng)用replace 等正則相關(guān)函數(shù)時(shí),是否有必要特殊處理下上述存在情況呢?
測(cè)試代碼:
var str = "姓名:{NAME}";
var str2 = "$<jesse$<";
document.write(str.replace(/\{NAME}/g,str2));
document.write("<br />");
document.write(str.replace(/\{NAME}/g,str2.replace(/\$/g,'$$$$')));//注意這里是四個(gè)“$”
頁面顯示:
姓名:{NAME}lt;jesse{NAME}lt;
姓名:$<jesse$<
你還可以自己測(cè)試下:
var str = "姓名:{NAME}";
var str2 = "$<jesse$<";
document.write(str.replace(/\{NAME}/g,str2.replace(/\$/g,'$$')));
比較好的做法是:
function tplReplace(str,json){
return str.replace(/{(\w+)}/gi,function(a,b){
return b in json ? json[b] : a;
}
}
- JavaScript字符串對(duì)象replace方法實(shí)例(用于字符串替換或正則替換)
- javascript 正則替換 replace(regExp, function)用法
- JavaScript replace(rgExp,fn)正則替換的用法
- javascript replace()正則替換實(shí)現(xiàn)代碼
- js正則函數(shù)match、exec、test、search、replace、split使用介紹集合
- JS利用正則配合replace替換指定字符
- js使用正則實(shí)現(xiàn)ReplaceAll全部替換的方法
- JS使用replace()方法和正則表達(dá)式進(jìn)行字符串的搜索與替換實(shí)例
- js正則表達(dá)式之replace函數(shù)用法
- js字符串替換所有的指定字符或文字(推薦replaceAll方法)
- js使用Replace結(jié)合正則替換重復(fù)出現(xiàn)的字符串功能示例
相關(guān)文章
notepad++ 等用正則表達(dá)式自動(dòng)添加sql引號(hào)的技巧
本篇文章給大家介紹notepad用正則表達(dá)式自動(dòng)添加sql引號(hào)的技巧,,需要的朋友可以參考下2015-10-10js 正則學(xué)習(xí)小記之匹配字符串字面量?jī)?yōu)化篇
昨天在《js 正則學(xué)習(xí)小記之匹配字符串字面量》談到 /"(?:\\.|[^"])*"/ 是個(gè)不錯(cuò)的表達(dá)式,因?yàn)榭梢詽M足我們的要求,所以這個(gè)表達(dá)式可用,但不一定是最好的2020-04-04根據(jù)身份證號(hào)碼計(jì)算出生日期、年齡、性別(18位) 根據(jù)入職時(shí)間計(jì)算工齡。
適用于OA項(xiàng)目中這些對(duì)檔案的管理,需要的朋友可以參考下2012-08-08asp正則表達(dá)式匹配數(shù)字$數(shù)字$數(shù)字$
用asp實(shí)現(xiàn)的匹配:數(shù)字$數(shù)字$數(shù)字$...... 的正則2008-04-04使用正則表達(dá)式生成隨機(jī)數(shù)據(jù)的方法
這篇文章主要介紹了使用正則表達(dá)式生成隨機(jī)數(shù)據(jù)的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02JavaScript RegExp 正則表達(dá)式對(duì)象詳細(xì)說明
RegExp 對(duì)象表示正則表達(dá)式,它是對(duì)字符串執(zhí)行模式匹配的強(qiáng)大工具。2010-12-12