黄色网页视频 I 影音先锋日日狠狠久久 I 秋霞午夜毛片 I 秋霞一二三区 I 国产成人片无码视频 I 国产 精品 自在自线 I av免费观看网站 I 日本精品久久久久中文字幕5 I 91看视频 I 看全色黄大色黄女片18 I 精品不卡一区 I 亚洲最新精品 I 欧美 激情 在线 I 人妻少妇精品久久 I 国产99视频精品免费专区 I 欧美影院 I 欧美精品在欧美一区二区少妇 I av大片网站 I 国产精品黄色片 I 888久久 I 狠狠干最新 I 看看黄色一级片 I 黄色精品久久 I 三级av在线 I 69色综合 I 国产日韩欧美91 I 亚洲精品偷拍 I 激情小说亚洲图片 I 久久国产视频精品 I 国产综合精品一区二区三区 I 色婷婷国产 I 最新成人av在线 I 国产私拍精品 I 日韩成人影音 I 日日夜夜天天综合

JavaScript--正則表達(dá)式

系統(tǒng) 3222 0

JavaScript--正則表達(dá)式

  正則表達(dá)式(regular expression)對象包含一個(gè)正則表達(dá)式模式(pattern)。它具有用正則表達(dá)式模式去匹

配或代替一個(gè)串(string)中特定字符(或字符集合)的屬性(properties)和方法(methods)。

正則表達(dá)式構(gòu)造函數(shù): new RegExp("pattern"[,"flags"]);
參數(shù)說明:
pattern -- 一個(gè)正則表達(dá)式文本
flags -- 如果存在,將是以下值:
g: 全局匹配
i: 忽略大小寫
gi: 以上組合

在構(gòu)造函數(shù)中,一些特殊字符需要進(jìn)行轉(zhuǎn)意(在特殊字符前加"/")。正則表達(dá)式中的特殊字符:
字符 含意
/ 轉(zhuǎn)意,即通常在"/"后面的字符不按原來意義解釋,如/b/匹配字符"b",當(dāng)b前面加了反斜桿后//b/,轉(zhuǎn)意為

匹配一個(gè)單詞的邊界。
-或-
對正則表達(dá)式功能字符的還原,如"*"匹配它前面元字符0次或多次,/a*/將匹配a,aa,aaa,加了"/"后,/a/*/

將只匹配"a*"。
^ 匹配一個(gè)輸入或一行的開頭,/^a/匹配"an A",而不匹配"An a"
$ 匹配一個(gè)輸入或一行的結(jié)尾,/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),匹配這個(gè)集合中的任一一個(gè)字符(或元字符)
[^xyz] 不匹配這個(gè)集合中的任何一個(gè)字符
[/b] 匹配一個(gè)退格符
/b 匹配一個(gè)單詞的邊界
/B 匹配一個(gè)單詞的非邊界
/cX 這兒,X是一個(gè)控制符,//cM/匹配Ctrl-M
/d 匹配一個(gè)字?jǐn)?shù)字符,//d/ = /[0-9]/
/D 匹配一個(gè)非字?jǐn)?shù)字符,//D/ = /[^0-9]/
/n 匹配一個(gè)換行符
/r 匹配一個(gè)回車符
/s 匹配一個(gè)空白字符,包括/n,/r,/f,/t,/v等
/S 匹配一個(gè)非空白字符,等于/[^/n/f/r/t/v]/
/t 匹配一個(gè)制表符
/v 匹配一個(gè)重直制表符
/w 匹配一個(gè)可以組成單詞的字符(alphanumeric,這是我的意譯,含數(shù)字),包括下劃線,如[/w]匹配"$5.98"

中的5,等于[a-zA-Z0-9]
/W 匹配一個(gè)不可以組成單詞的字符,如[/W]匹配"$5.98"中的$,等于[^a-zA-Z0-9]。


說了這么多了,我們來看一些正則表達(dá)式的實(shí)際應(yīng)用的例子:
HTML代碼的屏蔽
function mask_HTMLCode(strInput) {
var myReg = /<(/w+)>/;
return strInput.replace(myReg, "&lt;$1&gt;");
}
E-mail地址驗(yàn)證:
function test_email(strEmail) {
var myReg = /^[_a-z0-9]+@([_a-z0-9]+/.)+[a-z0-9]{2,3}$/;
if(myReg.test(strEmail)) return true;
return false;
}

正則表達(dá)式對象的屬性及方法:
  預(yù)定義的正則表達(dá)式擁有有以下靜態(tài)屬性:input, multiline, lastMatch, lastParen, leftContext,

rightContext和$1到$9。其中input和multiline可以預(yù)設(shè)置。其他屬性的值在執(zhí)行過exec或test方法后被根據(jù)

不同條件賦以不同的值。許多屬性同時(shí)擁有長和短(perl風(fēng)格)的兩個(gè)名字,并且,這兩個(gè)名字指向同一個(gè)值。(

JavaScript模擬perl的正則表達(dá)式)

正則表達(dá)式對象的屬性:
屬性 含義
$1...$9 如果它(們)存在,是匹配到的子串
$_ 參見input
$* 參見multiline
$& 參見lastMatch
$+ 參見lastParen
$` 參見leftContext
$''          參見rightContext
constructor    創(chuàng)建一個(gè)對象的一個(gè)特殊的函數(shù)原型
global       是否在整個(gè)串中匹配(bool型)
ignoreCase     匹配時(shí)是否忽略大小寫(bool型)
input        被匹配的串
lastIndex     最后一次匹配的索引
lastParen     最后一個(gè)括號(hào)括起來的子串
leftContext    最近一次匹配以左的子串
multiline     是否進(jìn)行多行匹配(bool型)
prototype     允許附加屬性給對象
rightContext    最近一次匹配以右的子串
source       正則表達(dá)式模式
lastIndex     最后一次匹配的索引

正則表達(dá)式對象的方法:
方法 含義
compile      正則表達(dá)式比較
exec        執(zhí)行查找
test        進(jìn)行匹配
toSource      返回特定對象的定義(literal

representing),其值可用來創(chuàng)建一個(gè)新的對象。重載Object.toSource方法得到的。
toString      返回特定對象的串。重載Object.toString方法得到的。
valueOf      返回特定對象的原始值。重載Object.valueOf方法得到

例子:
<script language = "JavaScript">
var myReg = /(w+)s(w+)/;
var str = "John Smith";
var newstr = str.replace(myReg, "$2, $1");
document.write(newstr);
</script>
將輸出"Smith, John"

JavaScript--正則表達(dá)式

JavaScript--正則表達(dá)式


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動(dòng)力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會(huì)非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論