首頁  >  文章  >  web前端  >  正規表示式中特殊符號及正規表示式的幾種方法總結(replace,test,search)_javascript技巧

正規表示式中特殊符號及正規表示式的幾種方法總結(replace,test,search)_javascript技巧

WBOY
WBOY原創
2016-05-16 17:12:401382瀏覽

一 正则表达式的正文。
正则表达式中使用了特殊符号。下面我就将各种符号以及其意义和用法简单的介绍一下(说明:"X以上包括X"):

/ 表示在其后的文字是特殊符号。例:"n"和"n"是一致的。"/n"和换行符是一致的。
^ 和输入的开始一致。
$ 和输入的结尾一致。
* 与此符号之前的文字0次以上相同的话,两者一致。例:"zo*"和"zoo","z"都一致。
+ 与此符号之前的文字1次以上相同的话,两者一致。例:"zo*"和"zoo"一致,但和"z"不一致。
? 与此符号之前的文字0次或1次相同的话,两者一致。例:"a?ve?"和"never"的"ve"一致。
. 与除了换行符的所有单一文字一致。
(正则表达式) 以所指定的表达式寻找一致文字。如果找到了,储存下来。一致的部分可以从
Match方法获得的阵列中找到。
x|y x和y的任意一方相同都会被认为一致。例:"(z|f)ood"和"zood","food"都一致。
{n} n是0以上的整数。与其前的文字n次相同的话,两者一致。例:"o{2}"和"Bob"中的"o"不一
致,与"foooood"中的前两个"o"一致。
{n,} n是0以上的整数。与其之前的文字至少n次相同才一致。
{n,m} 两者整数。n至m范围的次数一致。
[xyz] 与中括号中的文字任意一个相同都被认为一致。
[^xyz] 与上面的相反。
[a-z] 文字的范围,从"a"到"z"的文字都被认为一致。
[^a-z] 与上面的相反。
/b 表示单词的末尾。例:"er/b"和"never"的"er"一致,但和"verb"的"er"不一致。
/B 表示非单词的末尾。
/d 表示数字。
/D 表示非数字。
/s 表示空格。
/S 表示非空格。
/w 表示所有字母数字。
/W 表示非所有字母数字。

   i   (忽略大小写)  
  g   (全文查找出现的所有   pattern)  
  gi   (全文查找、忽略大小写)
/num num应该被赋予一个正数。与已经储存的部分比较。例:"(.)/1"和任意的两个连续的相同
文字一致。

二 如何定义一句正文:
方法一:直接写
var s=/正则表达式/i或g或ig

方法二:建立对象实例:
var s=new RegExp(正则表达式,i或g或ig)


三 与正则表达式有关的方法:

1 exec方法
描述: 在制定的文字行内进行搜索。
结构: 正则表达式.exec(字符串)。
解说: 检索的返回:
null 没有检索到;
一致的结果 检索到后;
例:
代码片段如下:
<script> <br>var s='AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPp' <br>var r=new RegExp('g','i'); <br>var a=r.exec(s); <br>alert(a); <br></script>

2 compile方法:
描述: 修改正则表现的内部形式。
结构: 正则表达.compile('正文','g或i或ig')。
解说: 没什么好说的。
例:
代码片段如下:
<script> <br>var s='AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPp' <br>var r=new RegExp('[A-Z]','g'); <br>var a=s.match(r); <br>alert(a); <br>r.compile('[a-z]','g'); <br>var a=s.match(r); <br>alert(a); <br></script>


3 test方法:
描述: 顾名思义,做测验。
结构: 正则表达.test(字符串)。
解说: 返回:
false 没找到;
true 找到了;
例:
代码片段如下:
<script> <br>var re=/re/g; <br>var msg='return'; <br>var msg1='goon'; <br>alert(re.test(msg)); <br>alert(re.test(msg1)); <br></script>


4 replace方法:
描述: 寻找一致的并置换他。
结构: 字符串.replace(正则表达,替换字符串)。
解说: 与字符串不变化,返回其副本。
例:
代码片段如下:
<script> <br>var s='AaBbCcDdEeFfGgHhIiJjKkLlMmNnOoPp' <br>var r=new RegExp('[A-Z]','g'); <br>var a=s.replace(/[a-z]/g,'A'); <br>alert(a); <br></script>


5 match方法:
描述: 实行检索。
结构: 字符串.match(正则表达)。
解说: 返回数列。
例:
代码片段如下:
<script> <br>var re=/re/g; <br>var msg='rererere'; <br>var msg1='goon'; <br>alert(msg.match(re)); <br>alert(msg1.match(re)); <br></script>


6 split方法:
描述: 分割字符串。
结构: 字符串.split(正则表达)。
解说: 返回数列。
例:
代码片段如下:
<script> <br>var s="hello this good world"; <br>var p=//s/g; <br>var a=s.split(p); <br>alert(a); <br></script>


7 search方法:
描述: 傳回一致的字串的位置。 (這比indexOf可用途廣多了!)
結構: 字串.search(正規表達)。
解說: 回傳
正整數如果找到了
-1 如果沒找到
例:
程式碼片段如下:
<script> <BR>var s="hello this good world"; <BR>var p=/good/g; <BR>var a=s.search(p); <BR>alert(a); <BR></script>


把replace的方法的範例改一下:
程式碼片段如下:
<script> <BR>var s="hellOSCF"; <BR>var r=new RegExp("[A-Z ]","g"); <BR>s=s.replace(r,"a"); <BR>alert(s) <BR></script>


最後是他的各種屬性

1 lastIndex屬性:
描述: 設定檢索開始的位置,可以得到其值
結構: 正規表示.lastIndex(=值).
解說:
當lastIndex大於檢索文字長度的時候,如果用test,exec方法執行的話,執行失敗,
lastIndex屬性被設定為0.
當lastIndex等於檢索文字長度的時候,如果表達式正文是空的話,一致.其他場合,
執行失敗,重設為0.
上記以外的情況,lastIndex會被設定為最後一致的文字列的位置指針.

2 source屬性
描述: 傳回正規表達的正文
結構: 正規表示.source
例:
程式碼片段如下:
<script> <BR>var s=/ [a-z]{3}/W/s/g; <BR>var s1=new RegExp("[a-z]{3}/W","g"); <BR>alert(s.source); <BR>alert(s1.source); <BR></script>

下面我將幾個處理字元函數寫出來:

1 嚴禁數字
程式碼片段如下:
function check(msg){
var exe=//d/g;
if(exe.test(msg))return(0) ;
else return(1)
}

2 只準字母
程式碼片段如下:
function check(msg){
var exe=//W/g;
if(exe.test(msg))return(0 );
else return(1);
}


3 嚴禁程式碼
程式碼片段如下:
function check(msg){
var exe=//g;
if( exe.test(msg))return(0);
else return(1);

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn