本文实例总结了javascript的replace方法结合正则使用方法。分享给大家供大家参考,具体如下:
replace()方法用于在字符串中用一些字符替换另一些字符,或者替换一个正则表达式匹配的字符串
例子一:直接使用repalce替换
var stringObj="终古人民共和国,终古人民"; //替换错别字“终古”为“中国” //并返回替换后的新字符 //原字符串stringObj的值没有改变 var newstr=stringObj.replace("终古","中国"); //中国人民共和国,终古人民 alert(newstr);
例子二:使用正则表达式,全部替换
var str="终古人民共和国,终古人民"; var newstr=str.replace(/(终古)/g,"中国"); //中国人民共和国,中国人民 alert(newstr);
等价于
var reg=new RegExp("终古","g"); //创建正则RegExp对象 var stringObj="终古人民共和国,终古人民"; var newstr=stringObj.replace(reg,"中国"); alert(newstr);
例子三:正则表达式,变量匹配
var resource="终古"; var target="中国"; var reg=new RegExp(resource,"g"); //创建正则RegExp对象 var stringObj="终古人民共和国,终古人民"; var newstr=stringObj.replace(reg,target); alert(newstr);
例子四:正则分组匹配
var strM = "javascript is a good script language"; //$1匹配的是javascript,$2匹配的是is //最终返回的值是"javascript is fun. it is" + strM //即javascript is 被替换为 javascript is fun. it is alert(strM.replace(/(javascript)\s*(is)/g,"$1 $2 fun. it $2"));
例子五:使用回调函数做详细处理
var name="aaa bbb ccc"; //name字符串去匹配/\b\w+\b/g表达式,结果有三个——aaa,bbb,ccc;每个结果执行function里面的方法 var uw = name.replace(/\b\w+\b/g,function(word){ //word是匹配的字符串 alert(word); return word.substring(0,1).toUpperCase()+word.substring(1); }); alert(uw);
例子六:比较生僻的写法
var reg=new RegExp("(http://www.qidian.com/BookReader/)(\\d+),(\\d+).aspx","gmi"); var url="http://www.qidian.com/BookReader/1017141,20361055.aspx"; //方式一,最简单常用的方式 var rep=url.replace(reg,"$1ShowBook.aspx?bookId=$2&chapterId=$3"); alert(rep); //方式二 ,采用固定参数的回调函数 var rep2=url.replace(reg,function(m,p1,p2,p3){ return p1+"ShowBook.aspx?bookId="+p3+"&chapterId="+p3 }); alert(rep2); //方式三,采用非固定参数的回调函数 var rep3=url.replace(reg,function(){ var args=arguments; return args[1]+"ShowBook.aspx?bookId="+args[2]+"&chapterId="+args[3]; }); alert(rep3);
function ReplaceDemo(){ var r, re; // 声明变量。 var ss = "The rain in Spain falls mainly in the plain."; // \s表示的是空格,则\S表示的是非空格,因此/(\S+)(\s+)(\S+)/g匹配的是“非空格空格非空格”的结果 //匹配的结果有The rain、in Spain、falls mainly、in the //替换后的结果有rain The、Spain in、mainly falls、the in re = /(\S+)(\s+)(\S+)/g; // 创建正则表达式模式。 //更改匹配结果之间的顺序 r = ss.replace(re, "$3$2$1"); // 交换每一对单词。 return(r); // 返回结果字符串。 } alert(ReplaceDemo());
name = "Doe, John"; //更改两个单词之间的顺序 var temp = name.replace(/(\w+)\s*, \s*(\w+)/, "$2 $1"); alert(temp);
function SDReplaceData(objStr) { return objStr.replace( /(\&|\')/g, function($0, $1) { return{ "&" : "&" , "'" : "'" }[$1]; } ); }
PS:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:
JavaScript正则表达式在线测试工具:
http://tools.jb51.net/regex/javascript
正则表达式在线生成工具:
http://tools.jb51.net/regex/create_reg
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《JavaScript切换特效与技巧总结》、《JavaScript查找算法技巧总结》、《JavaScript动画特效与技巧汇总》、《JavaScript错误与调试技巧总结》、《JavaScript数据结构与算法技巧总结》、《JavaScript遍历算法与技巧总结》及《JavaScript数学运算用法总结》
希望本文所述对大家JavaScript程序设计有所帮助。
本文向大家介绍javascript实用方法总结,包括了javascript实用方法总结的使用技巧和注意事项,需要的朋友参考一下 引言: 本章没有深奥的讲解js一些底层原理,比如this指针、作用域、原型啦,涉及的都是一些有利于平时开发时简化代码,提高执行效率,或者说可以当做一种经验方法来使用,篇幅都不长,小步快跑的让你阅读完整篇文章,体验编程的快乐。 获取两个区间之内随机数 随机返回一个 正
本文向大家介绍javascript中replace( )方法的使用,包括了javascript中replace( )方法的使用的使用技巧和注意事项,需要的朋友参考一下 最近在浏览一些阿里的前端面试题,其中有一题涉及了javascript中replace( )方法的使用,下面是原题: “说出以下函数的作用是?空白区域应该填写什么?” 以下是分析过程(感觉还是弄个编号,个人觉得比较有条理一些) 1、因
本文向大家介绍Android结合kotlin使用coroutine的方法实例,包括了Android结合kotlin使用coroutine的方法实例的使用技巧和注意事项,需要的朋友参考一下 最近入了Android坑,目前还处于疯狂学习的状态,所以很久都没有写博客了。今天记录一个小代码片段,在Android上使用coroutine 的小例子。 由于我自己是做一个记账软件来学习的,我用了gRPC,最开始
本文向大家介绍js正则查找match()与替换replace()用法实例,包括了js正则查找match()与替换replace()用法实例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js中正则的查找match()与替换replace()的用法。分享给大家供大家参考。具体如下: 希望本文所述对大家的正则表达式学习有所帮助。
本文向大家介绍js使用Replace结合正则替换重复出现的字符串功能示例,包括了js使用Replace结合正则替换重复出现的字符串功能示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了js使用Replace结合正则替换重复出现的字符串功能。分享给大家供大家参考,具体如下: 今天想把网站上关于用户搜索资料后的结果列表进行处理,如同百度搜索一样,加入我搜索框中输入“我要日日发网络”,点击搜索
本文向大家介绍JavaScript中Array对象用法实例总结,包括了JavaScript中Array对象用法实例总结的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了JavaScript中Array对象用法。分享给大家供大家参考,具体如下: Array数组对象有很多常用的方法和属性,现总结如下: 1. length属性,获取数组中元素的个数。 2. concat()方法,连接两个数组。将两