javascript中expression的用法整理
更新時間:2014年05月13日 17:08:01 作者:
在學(xué)習(xí)javaScript, 學(xué)到regular expression的時候見知識點有些雜亂,于是將其整理了一些在本文與大家分享
小哥我最近在學(xué)習(xí)javaScript, 學(xué)到regular expression的時候見知識點有些雜亂,所以特別寫篇博客做個總結(jié)。
定義
在javascript里定義reg exp有兩種方法:
1) 用new exp : var exp1 = new exp("abc");
2) 直接在兩個/中間放pattern: var exp2 = /abc/; //注意。。沒有雙引號喲, 加了就成string了
特殊字符
目測特殊字符和perl的是一樣的。。直接拿來用就好
\d Digit characters
\w Alphanumeric characters (“word characters”)
\s Whitespace characters (space, tab, newline, and similar)
\D Characters that are not digits
\W Non-alphanumeric characters
\S Non-whitespace characters
. A period matches all characters except newlines
有個很簡單的記的方法:
d = digit 所以是數(shù)字
w = word 所以是字母
s = space 所以是空格
所有大寫全是反的。。
括號[]
在括號中放pattern 代表只要符合任意字符都為真。 (和java 或者 Perl都是一樣一樣的)
比如
console.log(/[01]/.test("023424")); // true
console.log(/[01]/.test("13424")); // true
console.log(/[01]/.test("23424")); // false
括號()
表示要符合括號里的全部才會為真
比如
console.log(/[01]/.test("013424")); // true
console.log(/[01]/.test("13424")); // false
console.log(/[01]/.test("230424")); // false
console.log(/[01]/.test("230142401")); // true
Quantifiers
和java是一樣一樣一樣的。。 這個表很好。。小哥我一直喜歡用
expression object functions
1) test 這個很簡單,只用把要test的string放到test(...)里,這個function就會return true/false 代表 match/unmatch
2) exec, 這個function返還null如果沒有找到match的string.. 如果找到了就會返還一個array. 這個里邊包含按順序match的string
3) String.replace(expression1, string1) 這個function把expression中match的部分換成string1, string1里可以用之前expression中的parenthesized group
,來替代其中的某個部分。 比如說"co-ol".replace(/[\w]+\-[\w]+/,"$2-$1"); //"ol-co" 一直可以用到$9
4)String.replace(expression, function) 這個是加強版,而且很強大, 可以通過function來定義任何你想要的output。具體用法不在這里一一列出,請參考
點擊打開鏈接
動態(tài)生成reg expression
當(dāng)你想要用在reg exp里的東西只有runtime才知道的時候,這個方法就可以適用
生成reg exp其實只需要用string 建好reg exp的樣子, 再用Exp的constructor就可以。 (在文章開頭的地方提到過)
例如:
var name = "dear"
“oh, my dear”.replace(new Exp(name), "god"); // oh, my god
但是如果名字中有特殊字符可能會用在regular expression的時候, 往往上邊的方法會出錯。
所以, 在那種情況下,我們可以把input string的每一個字符的前邊都加上反斜杠 比如:
var name = df[]vxv;
var expName = name.replace("/[^/w/s]/g","\\$&");
"my name is df[]vxv".replace(new Exp(name), "Bob"); // my name is Bob
定義
在javascript里定義reg exp有兩種方法:
1) 用new exp : var exp1 = new exp("abc");
2) 直接在兩個/中間放pattern: var exp2 = /abc/; //注意。。沒有雙引號喲, 加了就成string了
特殊字符
目測特殊字符和perl的是一樣的。。直接拿來用就好
\d Digit characters
\w Alphanumeric characters (“word characters”)
\s Whitespace characters (space, tab, newline, and similar)
\D Characters that are not digits
\W Non-alphanumeric characters
\S Non-whitespace characters
. A period matches all characters except newlines
有個很簡單的記的方法:
d = digit 所以是數(shù)字
w = word 所以是字母
s = space 所以是空格
所有大寫全是反的。。
括號[]
在括號中放pattern 代表只要符合任意字符都為真。 (和java 或者 Perl都是一樣一樣的)
比如
復(fù)制代碼 代碼如下:
console.log(/[01]/.test("023424")); // true
console.log(/[01]/.test("13424")); // true
console.log(/[01]/.test("23424")); // false
括號()
表示要符合括號里的全部才會為真
比如
復(fù)制代碼 代碼如下:
console.log(/[01]/.test("013424")); // true
console.log(/[01]/.test("13424")); // false
console.log(/[01]/.test("230424")); // false
console.log(/[01]/.test("230142401")); // true
Quantifiers
和java是一樣一樣一樣的。。 這個表很好。。小哥我一直喜歡用
| Greedy | Reluctant | Possessive | Meaning |
|---|---|---|---|
| X? | X?? | X?+ | X, once or not at all |
| X* | X*? | X*+ | X, zero or more times |
| X+ | X+? | X++ | X, one or more times |
| X{n} | X{n}? | X{n}+ | X, exactly n times |
| X{n,} | X{n,}? | X{n,}+ | X, at least n times |
| X{n,m} | X{n,m}? | X{n,m}+ | X, at least n but not more thanm times |
expression object functions
1) test 這個很簡單,只用把要test的string放到test(...)里,這個function就會return true/false 代表 match/unmatch
2) exec, 這個function返還null如果沒有找到match的string.. 如果找到了就會返還一個array. 這個里邊包含按順序match的string
3) String.replace(expression1, string1) 這個function把expression中match的部分換成string1, string1里可以用之前expression中的parenthesized group
,來替代其中的某個部分。 比如說"co-ol".replace(/[\w]+\-[\w]+/,"$2-$1"); //"ol-co" 一直可以用到$9
4)String.replace(expression, function) 這個是加強版,而且很強大, 可以通過function來定義任何你想要的output。具體用法不在這里一一列出,請參考
點擊打開鏈接
動態(tài)生成reg expression
當(dāng)你想要用在reg exp里的東西只有runtime才知道的時候,這個方法就可以適用
生成reg exp其實只需要用string 建好reg exp的樣子, 再用Exp的constructor就可以。 (在文章開頭的地方提到過)
例如:
復(fù)制代碼 代碼如下:
var name = "dear"
“oh, my dear”.replace(new Exp(name), "god"); // oh, my god
但是如果名字中有特殊字符可能會用在regular expression的時候, 往往上邊的方法會出錯。
所以, 在那種情況下,我們可以把input string的每一個字符的前邊都加上反斜杠 比如:
復(fù)制代碼 代碼如下:
var name = df[]vxv;
var expName = name.replace("/[^/w/s]/g","\\$&");
"my name is df[]vxv".replace(new Exp(name), "Bob"); // my name is Bob
相關(guān)文章
js父窗口關(guān)閉時子窗口隨之關(guān)閉完美解決方案
admin注銷的時候,或者main.html關(guān)閉的時候,如何讓打開的所有新窗口一起關(guān)閉,下面有個不錯的解決方案,大家可以參考下2014-04-04
JavaScript實現(xiàn)離開頁面前提示功能【附j(luò)Query實現(xiàn)方法】
這篇文章主要介紹了JavaScript實現(xiàn)離開頁面前提示功能,結(jié)合具體實例形式分析了javascript實現(xiàn)針對關(guān)閉頁面的事件響應(yīng)原理與操作技巧,并附帶jQuery的相應(yīng)實現(xiàn)方法,需要的朋友可以參考下2017-09-09
淺談js在html中的加載執(zhí)行順序,多個jquery ready執(zhí)行順序
下面小編就為大家?guī)硪黄獪\談js在html中的加載執(zhí)行順序,多個jquery ready執(zhí)行順序。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11
JavaScript手寫源碼之實現(xiàn)arrify轉(zhuǎn)數(shù)組
這篇文章主要為大家詳細介紹了如何利用JavaScript實現(xiàn)arrify轉(zhuǎn)數(shù)組,文中的示例代碼講解詳細,對我們學(xué)習(xí)JavaScript有一點的幫助,需要的可以參考一下2023-02-02

