日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

EcmaScript正則表達式( 深入淺出系列之淺出 )

發布時間:2023/12/15 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 EcmaScript正則表達式( 深入淺出系列之淺出 ) 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?來源:http://www.v-ec.com/dh20156/article.asp?id=202

使用方法

創建對象
??? var r = new RegExp("表達式","ig");
??? 適合在動態構造匹配對象時使用;
??? 表達式中轉義符需要使用兩次,如//d;


直接量
??? var r = /表達式/ig;
??? 使用在任何固定模式的匹配;

常用屬性

$1...$9
??? 返回九個在模式匹配期間找到的、最近保存的部分。只讀。
index
??? 返回第一個成功匹配的開始位置。只讀。
lastIndex??? *(注意)
??? 返回最后一次成功匹配的位置(下一次匹配開始的位置)。讀寫。
??? 只有當使用exec()或test()函數時才會寫入。
lastMatch
??? 返回最后匹配的字符。只讀。
input
??? 返回查找的字符串。只讀。

lastIndex

考慮以下代碼:

<script type="text/javascript">

var r = //d/g;

alert(r.test('abc1'));
alert(r.lastIndex);

alert(r.test('ab1'));
alert(r.lastIndex);

alert(r.test('a1'));
alert(r.lastIndex);

</script>

lastIndex屬于實例屬性

當一個正則表達式實例多次test或exec時,它的lastIndex將每一次都被更改。

量詞

?
??? 出現0次或1次
*
??? 出現0次或多次
+
??? 出現1次或多次
{n}
??? 一定出現n次
{n,m}
??? 至少出現n次,最多出現m次
{n,}
??? 至少出現n次

貪婪與非貪婪(惰性)的量詞

貪婪匹配:
?
*
+
{n}
{n,m}
{n,}

非貪婪匹配:
??
*?
+?
{n}?
{n,m}?
{n,}?

貪婪與非貪婪的匹配過程

考慮以下代碼:

<script type="text/javascript">

var s = 'http://www/hello/world.php';

var r1 = /.*///g;

var r2 = /.*?///g;


alert(s.match(r1));

alert(s.match(r2));

</script>

//貪婪匹配
匹配整個字符串
從后逐一舍去最后一個字符繼續
http://www/hello/

//非貪婪匹配
從第一個字符開始匹配
如果失敗,讀入下一個字符繼續
http:/,??? /,??? www/,??? hello/

分組、反向引用與非捕獲性分組

用來匹配以一系列字符為一個單位的模式
??? (一系列的字符作為一個整體哦)
每創建一個分組,在執行test()、match()、search()、replace()后,可以通過全局$1...$9屬性來獲取匹配到的每一個分組。
分組匹配將帶來一定的效率損耗,如果有時候不需要獲取分組的結果,可以使用非捕獲性分組:(?:一系列的字符)

候選

用來匹配a or b or n...模式。比如,匹配文件類型:

<script type="text/javascript">

var s = 'http://www/hello/world.png.php';

var r = /(?:jpg|gif|png)$/i;

alert(r.test(s));

</script>

前瞻

正向前瞻
??? var r = /(aaa(?=bbb))/;
??? 用于匹配后面緊挨著的是bbb的串aaa


負向前瞻
??? var r = /(aaa(?!bbb))/;
??? 用于匹配后面緊挨著的不是bbb的串aaa

Replace

Replace中使用正則,第二個參數是函數!

<script type="text/javascript">
var str = 'aaZbbZccZ';
var s = str.replace(/(.*?)Z/g,
function(){
??? var ar = [];
??? for(var i=0;i<arguments.length;i++){
??????? ar.push(arguments[i]);
??? }
??? alert(ar);
??? ar.length = 0;
??? return arguments[2];
}
);
alert(s);
</script>


當有反向引用時:
arguments[0]:匹配到的串
arguments[1]:$1
arguments[2]:$2
.............................
arguments[arguments.length-2]:匹配到的位置
arguments[arguments.length-1]:要匹配的字符串

否則,有3個形參:
arguments[0]:匹配到的串
arguments[1]:匹配到的位置
arguments[2]:要匹配的字符串
?

Replace應用

不用循環輸出一至一百:

<script type="text/javascript">

var sAAA = new Array(100+1).join("a");

var sNum = sAAA.replace(/a/g,function(){
??? return arguments[1]+1+"<br/>"
});

document.write(sNum);

</script>

替換所有<>為[]:

<script type="text/javascript">

var str = '<a>a</a><b>b</b><c>c</c>';

var s = str.replace(/(<)|>/g,function(x,y){
??? return (y)?'[':']';
});

alert(s);

</script>

PPT下載:http://www.v-ec.com/dh20156/code/EcmaScriptRegExp.ppt

總結

以上是生活随笔為你收集整理的EcmaScript正則表達式( 深入淺出系列之淺出 )的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。