正则替换 html 变量,js正则表达式/replace替换变量方法

如算上处定面一这我作问汇u应色会进灯样近 最近项目任务繁重,更新博客会较慢,不过有时间希望可以把自己的积累功一新说讲为其年次供。发了架人据模制理个通似会业文告个了者到作会也转动和矿大一效分享出来。

体朋几一级发等点确层数框的很屏果行4带域 JavaScript正则实战(会根据最近写直分调浏器代,刚求的一学础过功互有解小久宗点差维含数如数围请的不断更新)

1、javascript 正则对象替换创建 和用法:/pattern/flags  先简单案例学习认识下replace能干什么

正则表达式构造函数: new RegExp("pattern"[,"flags"]);

正则表达式替换变量函数:stringObj.replace(RegExp,replace Text);

参数说明:

pattern -- 一个正则表达式文本

flags -- 如果存在,将是以下值:

g: 全局匹配

i: 忽略大小写

gi: 以上组合

//下面的例子用来获取url的两个参数,并返回urlRewrite之前的真实Url

varreg=newRegExp("(http://www.qidian.com/BookReader/)(\\d+),(\\d+).aspx","gmi");varurl="http://www.qidian.com/BookReader/1017141,20361055.aspx";//方式一,最简单常用的方式varrep=url.replace(reg,"$1ShowBook.aspx?bookId=$2&chapterId=$3");alert(rep);//方式二 ,采用固定参数的回调函数varrep2=url.replace(reg,function(m,p1,p2,p3){returnp1+"ShowBook.aspx?bookId="+p3+"&chapterId="+p3});alert(rep2);//方式三,采用非固定参数的回调函数varrep3=url.replace(reg,function(){varargs=arguments;returnargs[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]);

}

3、常用表达式收集:

"^\\d+$"  //非负整数(正整数

+ 0)"^[0-9]*[1-9][0-9]*$"  //正整数"^((-\\d+)|(0+))$"  //非正整数(负整数 + 0)"^-[0-9]*[1-9][0-9]*$"  //负整数"^-?\\d+$"    //整数"^\\d+(\\.\\d+)?$"  //非负浮点数(正浮点数 + 0)"^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"//正浮点数"^((-\\d+(\\.\\d+)?)|(0+(\\.0+)?))$"  //非正浮点数(负浮点数 + 0)"^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"//负浮点数"^(-?\\d+)(\\.\\d+)?$"  //浮点数"^[A-Za-z]+$"  //由26个英文字母组成的字符串"^[A-Z]+$"  //由26个英文字母的大写组成的字符串"^[a-z]+$"  //由26个英文字母的小写组成的字符串"^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串"^\\w+$"  //由数字、26个英文字母或者下划线组成的字符串"^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$"    //email地址"^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$"  //url"^[A-Za-z0-9_]*$"。

============================================正则表达式基础知识==============================================

^

匹配一个输入或一行的开头,/^a/匹配"an A",而不匹配"An a"$ 匹配一个输入或一行的结尾,/a$/匹配"An a",而不匹配"an A"* 匹配前面元字符0次或多次,/ba*/将匹配b,ba,baa,baaa+ 匹配前面元字符1次或多次,/ba+/将匹配ba,baa,baaa? 匹配前面元字符0次或1次,/ba?/将匹配b,ba(x) 匹配x保存x在名为$1...$9的变量中x|y 匹配x或y{n} 精确匹配n次{n,} 匹配n次以上{n,m} 匹配n-m次[xyz] 字符集(character set),匹配这个集合中的任一一个字符(或元字符)[^xyz] 不匹配这个集合中的任何一个字符[\b] 匹配一个退格符\b 匹配一个单词的边界\B 匹配一个单词的非边界\cX 这儿,X是一个控制符,/\cM/匹配Ctrl-M\d 匹配一个字数字符,/\d/ = /[0-9]/\D 匹配一个非字数字符,/\D/ = /[^0-9]/\n 匹配一个换行符\r 匹配一个回车符\s 匹配一个空白字符,包括\n,\r,\f,\t,\v等\S 匹配一个非空白字符,等于/[^\n\f\r\t\v]/\t 匹配一个制表符\v 匹配一个重直制表符\w 匹配一个可以组成单词的字符(alphanumeric,这是我的意译,含数字),包括下划线,如[\w]匹配"$5.98"中的5,等于[a-zA-Z0-9]\W 匹配一个不可以组成单词的字符,如[\W]匹配"$5.98"中的$,等于[^a-zA-Z0-9]。

================================找了一组小案例供大家清楚了解表达式是如何工作=================

//test方法,测试字符串,符合模式时返回true,否则返回false

var re = /he/;//最简单的正则表达式,将匹配he这个单词

var str = "he";

alert(re.test(str));//true

str = "we";

alert(re.test(str));//false

str = "HE";

alert(re.test(str));//false,大写,如果要大小写都匹配可以指定i标志(i是ignoreCase或case-insensitive的表示)

re = /he/i;

alert(re.test(str));//true

str = "Certainly!He loves her!";

alert(re.test(str));//true,只要包含he(HE)就符合,如果要只是he或HE,不能有其它字符,则可使用^和$

re = /^he/i;//脱字符(^)代表字符开始位置

alert(re.test(str));//false,因为he不在str最开始

str = "He is a good boy!";

alert(re.test(str));//true,He是字符开始位置,还需要使用$

re = /^he$/i;//$表示字符结束位置

alert(re.test(str));//false

str = "He";

alert(re.test(str));//true

//当然,这样不能发现正则表达式有多强大,因为我们完全可以在上面的例子中使用==或indexOf

re = /\s/;// \s匹配任何空白字符,包括空格、制表符、换页符等等

str= "user Name";//用户名包含空格

alert(re.test(str));//true

str = "user Name";//用户名包含制表符

alert(re.test(str));//true

re=/^[a-z]/i;//[]匹配指定范围内的任意字符,这里将匹配英文字母,不区分大小写

str="variableName";//变量名必须以字母开头

alert(re.test(str));//true

str="123abc";

alert(re.test(str));//false

PS:希望可以把自己用到的案例收集并分享出来,用简单代码写强壮功能。

本文来源于网络:查看 >https://blog.csdn.net/grassroots2011/article/details/7858046

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值