javascript replace()第二个参数为函数时的参数用法
网络编程 2021-07-04 19:20www.168986.cn编程入门
replace()函数具有替换功能,它可以具有两个参数,第一个参数可以是要被替换的字符串或者匹配要被替换字符串的正则表达式,第二个参数可以是替换文本或者一个函数,狼蚁网站SEO优化看一下关于replace()函数的几个代码实例
javascript的replace()第二个参数为函数时的参数:
replace()函数具有替换功能,它可以具有两个参数,第一个参数可以是要被替换的字符串或者匹配要被替换字符串的正则表达式,第二个参数可以是替换文本或者一个函数,狼蚁网站SEO优化看一下关于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>
上面的代码中,第二个参数是一个函数,可以用此函数的返回值替换字符串中指定的子字符串。当第二个参数为函数的时候,其实这个函数可以传递参数的,狼蚁网站SEO优化就通过代码实例介绍一下关于函数的参数问题。
代码如下:
<!DOCTYPE html> <html> <head> <meta charset=" utf-8"> <title>狼蚁SEO</title> <script type="text/javascript"> var url = "https://.jb51./o.php?mod=viewthread&tid=14743&extra=page%3D1"; //第一参数为字符串 console.group("字符串"); var oneResult = url.replace(".jb51.",function(){ console.log("replace输入参数%o",arguments); var val = /.jb51./.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()函数第一参数是普通字符串和正则表达式的时候,第二个函数参数传递参数的情况,狼蚁网站SEO优化分别做一下简单的说明:
第一个参数是普通字符串:
当第一个参数是普通字符串的时候,那么只会替换原字符串中的第一个子字符串,也就是说只会执行一次替换操作,为函数传递的参数和以普通字符串参数作为正则表达式执行exec()函数返回的数组的元素是相同的。
第一个参数是正则表达式:
由于篇幅原因,这里只是截取了一部分运行结果内容,replace()函数的第一个参数是正则表达式,并且执行的是全局匹配,那么第二个函数参数会多次被调用,每次被调用传递的参数,也是和regexp_global.exec(url)返回的数组的元素内容是相同的。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程