首頁 >web前端 >js教程 >javascript replace()第二個參數為函數時的參數用法(詳細為大家解讀)

javascript replace()第二個參數為函數時的參數用法(詳細為大家解讀)

亚连
亚连原創
2018-05-19 13:45:432566瀏覽

replace()函數具有替換功能,它可以具有兩個參數,第一個參數可以是要被替換的字串或匹配要被替換字串的正則表達式,第二個參數可以是替換文本或者一個函數,下面看一下關於replace()函數的幾個程式碼實例

javascript的replace()第二個參數為函數時的參數:

replace()函數具有替換功能,它可以有兩個參數,第一個參數可以是要被替換的字串或符合要被取代字串的正規表示式,第二個參數可以是替換文字或者一個函數,下面看一下關於replace ()函數的幾個程式碼實例。
程式碼實例:
實例一:

<script>
var str="I love jb51 and you?";
console.log(str.replace("jb","java"));
</script>

#上面的程式碼只能夠替換字串中的第一個指定子字串。
實例二:

<script>
var str="I love jb51 and you?";
var reg=/jb/g;
console.log(str.replace(reg,"java"));
</script>

上面的程式碼可以將字串中的所有指定子字串替換掉。
實例三:

<script>
var str="I love jb51 and you?";
console.log(str.replace("jb",function(){
 return "java"}
));
</script>

上面的程式碼中,第二個參數是一個函數,可以用此函數的回傳值取代字串中指定的子字串。當第二個參數為函數的時候,其實這個函數可以傳遞參數的,下面就透過程式碼實例介紹一下關於函數的參數問題。
程式碼如下:

<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<title>脚本之家</title>
<script type="text/javascript">
var url = "http://www.jb51.net/o.php?mod=viewthread&tid=14743&extra=page%3D1";
//第一参数为字符串
console.group("字符串");
var oneResult = url.replace("www.jb51.net",function(){
 console.log("replace输入参数:%o",arguments);
 var val = /www.jb51.net/.exec(url);
 
 console.log("exec输出参数:%o",val);
              
 console.assert(arguments[0] === val[0]);
 console.assert(arguments[1] === val["index"]);
 console.assert(arguments[2] === val["input"]);
 return "jb51";
});
console.log("replace返回字符串:"+oneResult);
console.groupEnd("字符串");
    
//第一参数为正则表达式
console.group("正则表达式");
var regexp_global = /[?&](\w+)=([^&]*)/g;
var count = 0;
var twoResult = url.replace(regexp_global,function(){
 console.log("第"+(count++)+"次运行");
 console.log("replace输入参数:%o",arguments);
 var val = regexp_global.exec(url);
 console.log("exec输出参数:%o",val);
              
 console.assert(arguments[0] === val[0]);
 console.assert(arguments[1] === val[1]);
 console.assert(arguments[2] === val[2]);
 console.assert(arguments[3] === val["index"]);
 console.assert(arguments[4] === val["input"]);
 return count;
});
console.log("replace返回字符串:"+twoResult);
console.groupEnd("正则表达式");
</script>
</head>
<body>
 
</body>
</html>

在上面的程式碼中,分別示範了replace()函數第一參數是普通字串和正規表示式的時候,第二個函數參數傳遞參數的情況,下面分別做簡單的說明:
第一個參數是普通字串:

當第一個參數是普通字串的時候,那麼只會替換原始字串中的第一個子字串,也就是說只會執行一次替換操作,為函數傳遞的參數和以普通字串參數作為正則表達式執行exec()函數返回的數組的元素是相同的。
第一個參數是正規表示式:

由於篇幅原因,這裡只是截取了一部分運行結果內容,replace()函數的第一個參數是正規表示式,並且執行的是全域匹配,那麼第二個函數參數會被多次調用,每次被調用傳遞的參數,也是和regexp_global.exec(url)返回的數組的元素內容是相同的。

上面是我整理給大家的,希望今後對大家有幫助。

相關文章:

利用js取得今天是今年的第幾週(小範例,附有原始碼)

#暢談HTML CSS JS(詳細講解)

#關於如何最佳化你的JS程式碼(圖文教學)

以上是javascript replace()第二個參數為函數時的參數用法(詳細為大家解讀)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn