Javascript下str.replace进行变量替换

 

在实际前端开发中,我们使用replace进行字符串的替换,如:

var str = '1231';
str.replace('1','a'); //'a231'

 如果想要替换字符串中所有的某个字符,可以使用正则:

var str = '1231';
str.replace(/1/g,'a');  //'a23a'

但是如果我们想要替换变量,用上述的方法就不行了:

var str = '1231';
var c = '1';
str.replace(/c/g,'a'); //'1231'

其中的变量c在正则中默认变成了字符串‘c’,不会达到我们想要的效果,遇到这种情况,我们需要使用正则的方法RegExp;

var str = '1231';
var c = '1';
var reg = new RegExp(c,'g');
str.replace(reg,'a'); //'a23a'

这是一种replace中变量替换的通用方法。

//下面的例子用来获取url的两个参数,并返回urlRewrite之前的真实Url
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);
//方法四
//方式四和方法三很类似, 除了返回替换后的字符串外,还可以单独获取参数
var bookId;
var chapterId;
function capText()
{
    var args=arguments;
    bookId=args[2];
    chapterId=args[3];
    return args[1]+"ShowBook.aspx?bookId="+args[2]+"&chapterId="+args[3];
}

var rep4=url.replace(reg,capText);
alert(rep4);
alert(bookId);
alert(chapterId);
//使用test方法获取分组
var reg3=new RegExp("(http://www.qidian.com/BookReader/)(\\d+),(\\d+).aspx","gmi");
reg3.test("http://www.qidian.com/BookReader/1017141,20361055.aspx");
//获取三个分组
alert(RegExp.$1);
alert(RegExp.$2);
alert(RegExp.$3);
2、 学习最常用的 test exec match search  replace  split 6个方法
1) test  检查指定的字符串是否存在
var data = “123123″;
var reCat = /123/gi;
alert(reCat.test(data));  //true
//检查字符是否存在  g 继续往下走  i 不区分大小写
2) exec 返回查询值
var data = “123123,213,12312,312,3,Cat,cat,dsfsdfs,”;
var reCat = /cat/i;
alert(reCat.exec(data));  //Cat
3)match  得到查询数组
var data = “123123,213,12312,312,3,Cat,cat,dsfsdfs,”;
var reCat = /cat/gi;
var arrMactches = data.match(reCat)
for (var i=0;i < arrMactches.length ; i++)
{
alert(arrMactches[i]);   //Cat  cat
}
4) search  返回搜索位置  类似于indexof
var data = “123123,213,12312,312,3,Cat,cat,dsfsdfs,”;
var reCat = /cat/gi;
alert(data.search(reCat));  //23
5) replace  替换字符  利用正则替换
var data = “123123,213,12312,312,3,Cat,cat,dsfsdfs,”;
var reCat = /cat/gi;
alert(data.replace(reCat,”libinqq”));
6)split   利用正则分割数组
var data = “123123,213,12312,312,3,Cat,cat,dsfsdfs,”;
var reCat = /\,/;
var arrdata = data.split(reCat);
for (var i = 0; i < arrdata.length; i++)
{
alert(arrdata[i]);
}

时间: 2024-08-29 11:44:25

Javascript下str.replace进行变量替换的相关文章

javascript实现perl风格的变量替换

perl风格的变量替换有更好的可读性,普通的javascript编程中+号很多,让人眼花缭乱.好消息,我们可以用正则表达式来帮助实现编程风格的转换. 下面的例子中规定${}内的字符串是变量名,定义varReplace原型函数实现变量替换: String.prototype.varReplace = function(){ var pttrn = /\${(\w+)}/g; return this.replace(pttrn,function(a,b){return eval(b)}); } va

javascript下用ActiveXObject控件替换word书签,将内容导出到word后打印第1/2页_javascript技巧

最近有需求将数据导出到word里,然后编辑打印. 想过几种方案: 1.使用jacob. 2.使用apache的poi. 3.使用itext. 由于时间比较紧,没多的时候去学习研究上述工具包,现在用javascript操作ActiveXObject控件,用替换word模板中的书签方式解决. 前提条件: 1.浏览器安全级别降低,可以使用ActiveXObject控件. 2.装有office word. 目前实现了替换单个书签,多行表格书签,和图片,基本上满足需求.不过还有很多操作word的使用方法不

JavaScript 中的replace方法

 1第一次发现JavaScript中replace() 方法如果直接用str.replace("-","!") 只会替换第一个匹配的字符.  2而str.replace(/-/g,"!")则可以替换掉全部匹配的字符(g为全局标志). 3 4 5replace()  6The replace() method returns the string that results when you replace text matching its fir

JavaScript 中的replace方法说明_javascript技巧

第一次发现JavaScript中replace() 方法如果直接用str.replace("-","!") 只会替换第一个匹配的字符.   而str.replace(/\-/g,"!")则可以替换掉全部匹配的字符(g为全局标志).   replace()   The replace() method returns the string that results when you replace text matching its first a

javascript中正则replace 匹配替换变量的方法

先来个最基础的,看下面代码  代码如下 复制代码 var str = 'sasldfjlkdsjf'; console.log(str.replace(/sa/, '')); //sldfjlkdsjf这样就可以替换掉str字符串中的sa,现在如果sa是一个变量呢?  代码如下 复制代码 var reg = 'sa';那么 console.log(str.replace(/reg/, ''));//这样肯定是不对的         代码如下 复制代码 解决方法: var reg = 'ab';

JavaScript中的Replace函数替换的问题

今天同事问我一个关于JavaScript中替换的问题,他又一段字符串"</SheetItems><ElectricalStatus>",希望用"!"来替换"<",用了replace函数却发现只能替换掉第一个"<". 如: <script language="javascript"> var str="</SheetItems><El

javascript正则表达式使用replace()替换手机号的方法_javascript技巧

本文实例讲述了javascript正则表达式使用replace()替换手机号的方法.分享给大家供大家参考. 具体实现方法如下: 复制代码 代码如下: <html> <head> <title>javascript正则表达式使用replace()替换手机号</title> <meta http-equiv="content-type" content="text/html;charset=utf-8" />

JavaScript字符串对象replace方法实例(用于字符串替换或正则替换)_基础知识

JavaScript replace 方法 replace 方法用于在字符串中用一些字符串替换另一些字符串,或者替换符合正则匹配的字符串,并返回替换后的字符串.其语法如下: 复制代码 代码如下: str_object.replace(reg_exp/str, replacement) 参数说明: 参数 说明 str_object 要操作的字符串(对象) reg_exp/str 必需.要匹配的正则表达式/要替换的字符串 如果 reg_exp 具有全局标志 g,那么 replace() 方法将替换所

JavaScript使用Replace进行字符串替换的方法_javascript技巧

本文实例讲述了JavaScript使用Replace进行字符串替换的方法.分享给大家供大家参考.具体分析如下: var str='123123'; alert(str.replace('1','0')); //只替换第一处结果为023123 alert(str.replace(/1/g,'0')); //替换全部结果为023023 希望本文所述对大家的javascript程序设计有所帮助. 以上是小编为您精心准备的的内容,在的博客.问答.公众号.人物.课程等栏目也有的相关内容,欢迎继续使用右上角