因為.*表示點0到無數(shù)次重復,等同于.{0,},也就是說可以不重復(0次重復),所以你第二個正則表達式,可以等同于第一個正則表達式,因為.*可以為0次重復.

成都創(chuàng)新互聯(lián)公司主要從事網頁設計、PC網站建設(電腦版網站建設)、wap網站建設(手機版網站建設)、響應式網站、程序開發(fā)、網站優(yōu)化、微網站、小程序定制開發(fā)等,憑借多年來在互聯(lián)網的打拼,我們在互聯(lián)網網站建設行業(yè)積累了豐富的網站設計制作、網站建設、網站設計、網絡營銷經驗,集策劃、開發(fā)、設計、營銷、管理等多方位專業(yè)化運作于一體。
如果你把.*改成.+輸出就是false了,因為.+表示點1到無數(shù)次重復,等同于.{1,}
下面給你一個.+的例子,你看看吧,結果為false
script?type=text/javascript
var?pattem?=?/8go..+gle8/;?
var?str?=?'8google8';?
alert(pattem.test(str));
/script
運行結果
false
"." 表示:匹配除換行符以外的任意字符
如:888 8-8 8a8 等 中間可以寫任意字符
JavaScript通過RegExp類來支持正則表達式,舉一個最簡單的例子:
復制代碼
代碼如下:
var
regApple
=
new
RegExp("apple");
它可以匹配一個字符串中出現(xiàn)的第一個"apple"字符串,并且對大小寫敏感。在構造方法中加入第二個參數(shù)"g"則代表的搜索出字符串中所有的
"apple",這里"g"代表"global"。如果第二個參數(shù)為"i",則代表著case-insensitive,匹配過程中將不考慮字母的大小寫。將上述兩者綜合起來,可以搜索出所有"apple"字符串,并且不考慮大小寫問題。
復制代碼
代碼如下:
var
regApple
=
new
RegExp("apple",
"gi");
正則表達式有著并不唯一的表示方法,使用Perl語言中的語法,可以將上述表達式表示為:
復制代碼
代碼如下:
var
regApple
=
/apple/gi;
創(chuàng)建了一個RegExp對象后,RegExp的方法可以構造出不同的匹配方式,因為正則表達式是對字符串進行的操作,所以String的一些方法在構造正則表達式的過程中也扮演著重要角色。
RegExp對象的方法
復制代碼
代碼如下:
var
sampleString
=
"Greenapple";
var
regApple
=
/apple/;
alert(regApple.test(sampleString));
上面代碼輸出的結果是"true",因為sampleString中包含了需要匹配的字符串"apple",這是最簡單的檢測方式。有時,我們需要知道匹配的詳細結果,例如:
復制代碼
代碼如下:
var
sampleString
=
"green
apples,
red
apples";
var
regApple
=
/apple/g;
var
arr
=
regApple.exec(sampleString);
通過使用exec()方法,返回的arr是關于匹配結果的一個數(shù)組,包括每一個匹配的值及其所在的段,例如上例中是"green
apples"還是"red
apples"。match()方法有著和exec()相同的功能,只是表達方式不同:
復制代碼
代碼如下:
var
sampleString
=
"green
apples,
red
apples";
var
regApple
=
/apple/g;
var
arr
=
sampleString.match(regApple);
search()方法和indexOf()比較類似,返回第一個匹配的字符串所在的位置:
復制代碼
代碼如下:
var
sampleString
=
"green
apples,
red
apples";
var
regApple
=
/apple/gi;
alert(sampleString.search(regApple));
//輸出"6"
String的方法
String的replace()方法可以將指定的字符串替換為另一個字符串:
復制代碼
代碼如下:
var
sampleString
=
"There
is
a
green
apple.";
alert(sampleString.replace("green",
"red"));
//輸出"There
is
a
red
apple."
將replace()的第一個參數(shù)替換為一個正則表達式,可以達到同樣的效果:
復制代碼
代碼如下:
var
sampleString
=
"There
is
a
green
apple.";
var
regApple
=
/apple/;
alert(sampleString.replace(regApple,
"red"));
//輸出"There
is
a
red
apple."
replace()的第二個參數(shù)可以替換為一個function(),該function()接受一個匹配字符串作為參數(shù),返回一個替換字符串。(存在疑問)
使用正則表達式可以實現(xiàn)String的split()方法相同的功能。
復制代碼
代碼如下:
var
fruit
=
"apple,pear,lemon";
var
arr
=
fruit.split(",");
使用正則表達式:
復制代碼
代碼如下:
var
fruit
=
"apple,pear,lemon";
var
reg
=
/\,/;
var
arr
=
fruit.split(reg);
一、
當正則表達式中包含能接受重復的限定符時,通常的行為是(在使整個表達式能得到匹配的前提下)匹配盡可能多的字符。以這個表達式為例:a.*b,它將會匹配最長的以a開始,以b結束的字符串。如果用它來搜索aabab的話,它會匹配整個字符串aabab。這被稱為貪婪匹配。
二、
有時,我們更需要懶惰匹配,也就是匹配盡可能少的字符。前面給出的限定符都可以被轉化為懶惰匹配模式,只要在它后面加上一個問號?。這樣.*?就意味著匹配任意數(shù)量的重復,但是在能使整個匹配成功的前提下使用最少的重復。現(xiàn)在看看懶惰版的例子吧:
a.*?b匹配最短的,以a開始,以b結束的字符串。如果把它應用于aabab的話,它會匹配aab(第一到第三個字符)和ab(第四到第五個字符)。
三、代碼/語法 說明
① *? 重復任意次,但盡可能少重復
② +? 重復1次或更多次,但盡可能少重復
③ ?? 重復0次或1次,但盡可能少重復
④ {n,m}? 重復n到m次,但盡可能少重復
⑤ {n,}? 重復n次以上,但盡可能少重復
網站題目:正則javascript,正則表達式生成器
當前地址:http://chinadenli.net/article30/dsiosso.html
成都網站建設公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、靜態(tài)網站、做網站、Google、自適應網站、外貿建站
聲明:本網站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)