JavaScript正则实战(会根据最近写的不断更新)
1、javascript 正则对象替换创建 和用法: /pattern/flags 先简单案例学习认识下replace能干什么
正则表达式构造函数: new RegExp("pattern"[,"flags"]);
正则表达式替换变量函数:stringObj.replace(RegExp,replace Text);
参数说明:
pattern -- 一个正则表达式文本
flags -- 如果存在,将是以下值:
g: 全局匹配
i: 忽略大小写
gi: 以上组合
//下面的例子用来获取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]);
}
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 일치 $1이라는 파일에 x를 저장합니다. ..$9 변수에서
x|y는 x 또는 y와 일치합니다.
{n}은 정확히 n번과 일치합니다.
{n,}은 n번 이상 일치합니다.
{n,m}은 n-m번과 일치합니다.
[xyz ] 문자 집합, 이 집합의 모든 문자(또는 메타 문자)와 일치
[^xyz]는 이 집합의 어떤 문자와 일치하지 않음
[b] 백스페이스 문자와 일치
b 경계와 일치 단어
B는 단어의 경계가 아닌 문자와 일치합니다.
cX 여기서 X는 제어 문자이고, /cM/은 Ctrl-M과 일치합니다.
d는 영숫자 문자와 일치하며, /d/ = /[0 -9]/
D는 영숫자가 아닌 문자와 일치합니다. /D/ = /[^0-9]/
n은 개행 문자와 일치합니다.
r은 캐리지 리턴 문자와 일치합니다.
s는 a와 일치합니다. n, r, f, t, v 등을 포함한 공백 문자.
S는 /[^nfrtv]/와 같은 공백이 아닌 문자와 일치합니다.
t는 탭 문자와 일치합니다.
v는 반복과 일치합니다. 직선 탭 문자
w는 밑줄을 포함하여 단어를 구성할 수 있는 문자(영숫자, 숫자를 포함한 내 무료 번역)와 일치합니다. 예를 들어 [w]는 "$5.98"의 5와 일치합니다. [a-zA-Z0 -9]
W는 단어를 구성할 수 없는 문자와 일치합니다. 예를 들어 [W]는 "$5.98"의 $와 일치하며 이는 [^a-zA-Z0-9]와 같습니다. .
js 정규식 대체 변수 방법에 대한 더 많은 기사를 보려면 PHP 중국어 웹사이트를 주목하세요!