javascript中expression的用法整理
更新時(shí)間:2014年05月13日 17:08:01 作者:
在學(xué)習(xí)javaScript, 學(xué)到regular expression的時(shí)候見(jiàn)知識(shí)點(diǎn)有些雜亂,于是將其整理了一些在本文與大家分享
小哥我最近在學(xué)習(xí)javaScript, 學(xué)到regular expression的時(shí)候見(jiàn)知識(shí)點(diǎn)有些雜亂,所以特別寫(xiě)篇博客做個(gè)總結(jié)。
定義
在javascript里定義reg exp有兩種方法:
1) 用new exp : var exp1 = new exp("abc");
2) 直接在兩個(gè)/中間放pattern: var exp2 = /abc/; //注意。。沒(méi)有雙引號(hào)喲, 加了就成string了
特殊字符
目測(cè)特殊字符和perl的是一樣的。。直接拿來(lái)用就好
\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
有個(gè)很簡(jiǎn)單的記的方法:
d = digit 所以是數(shù)字
w = word 所以是字母
s = space 所以是空格
所有大寫(xiě)全是反的。。
括號(hào)[]
在括號(hào)中放pattern 代表只要符合任意字符都為真。 (和java 或者 Perl都是一樣一樣的)
比如
console.log(/[01]/.test("023424")); // true
console.log(/[01]/.test("13424")); // true
console.log(/[01]/.test("23424")); // false
括號(hào)()
表示要符合括號(hào)里的全部才會(huì)為真
比如
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是一樣一樣一樣的。。 這個(gè)表很好。。小哥我一直喜歡用
expression object functions
1) test 這個(gè)很簡(jiǎn)單,只用把要test的string放到test(...)里,這個(gè)function就會(huì)return true/false 代表 match/unmatch
2) exec, 這個(gè)function返還null如果沒(méi)有找到match的string.. 如果找到了就會(huì)返還一個(gè)array. 這個(gè)里邊包含按順序match的string
3) String.replace(expression1, string1) 這個(gè)function把expression中match的部分換成string1, string1里可以用之前expression中的parenthesized group
,來(lái)替代其中的某個(gè)部分。 比如說(shuō)"co-ol".replace(/[\w]+\-[\w]+/,"$2-$1"); //"ol-co" 一直可以用到$9
4)String.replace(expression, function) 這個(gè)是加強(qiáng)版,而且很強(qiáng)大, 可以通過(guò)function來(lái)定義任何你想要的output。具體用法不在這里一一列出,請(qǐng)參考
點(diǎn)擊打開(kāi)鏈接
動(dòng)態(tài)生成reg expression
當(dāng)你想要用在reg exp里的東西只有runtime才知道的時(shí)候,這個(gè)方法就可以適用
生成reg exp其實(shí)只需要用string 建好reg exp的樣子, 再用Exp的constructor就可以。 (在文章開(kāi)頭的地方提到過(guò))
例如:
var name = "dear"
“oh, my dear”.replace(new Exp(name), "god"); // oh, my god
但是如果名字中有特殊字符可能會(huì)用在regular expression的時(shí)候, 往往上邊的方法會(huì)出錯(cuò)。
所以, 在那種情況下,我們可以把input string的每一個(gè)字符的前邊都加上反斜杠 比如:
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) 直接在兩個(gè)/中間放pattern: var exp2 = /abc/; //注意。。沒(méi)有雙引號(hào)喲, 加了就成string了
特殊字符
目測(cè)特殊字符和perl的是一樣的。。直接拿來(lái)用就好
\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
有個(gè)很簡(jiǎn)單的記的方法:
d = digit 所以是數(shù)字
w = word 所以是字母
s = space 所以是空格
所有大寫(xiě)全是反的。。
括號(hào)[]
在括號(hào)中放pattern 代表只要符合任意字符都為真。 (和java 或者 Perl都是一樣一樣的)
比如
復(fù)制代碼 代碼如下:
console.log(/[01]/.test("023424")); // true
console.log(/[01]/.test("13424")); // true
console.log(/[01]/.test("23424")); // false
括號(hào)()
表示要符合括號(hào)里的全部才會(huì)為真
比如
復(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是一樣一樣一樣的。。 這個(gè)表很好。。小哥我一直喜歡用
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 這個(gè)很簡(jiǎn)單,只用把要test的string放到test(...)里,這個(gè)function就會(huì)return true/false 代表 match/unmatch
2) exec, 這個(gè)function返還null如果沒(méi)有找到match的string.. 如果找到了就會(huì)返還一個(gè)array. 這個(gè)里邊包含按順序match的string
3) String.replace(expression1, string1) 這個(gè)function把expression中match的部分換成string1, string1里可以用之前expression中的parenthesized group
,來(lái)替代其中的某個(gè)部分。 比如說(shuō)"co-ol".replace(/[\w]+\-[\w]+/,"$2-$1"); //"ol-co" 一直可以用到$9
4)String.replace(expression, function) 這個(gè)是加強(qiáng)版,而且很強(qiáng)大, 可以通過(guò)function來(lái)定義任何你想要的output。具體用法不在這里一一列出,請(qǐng)參考
點(diǎn)擊打開(kāi)鏈接
動(dòng)態(tài)生成reg expression
當(dāng)你想要用在reg exp里的東西只有runtime才知道的時(shí)候,這個(gè)方法就可以適用
生成reg exp其實(shí)只需要用string 建好reg exp的樣子, 再用Exp的constructor就可以。 (在文章開(kāi)頭的地方提到過(guò))
例如:
復(fù)制代碼 代碼如下:
var name = "dear"
“oh, my dear”.replace(new Exp(name), "god"); // oh, my god
但是如果名字中有特殊字符可能會(huì)用在regular expression的時(shí)候, 往往上邊的方法會(huì)出錯(cuò)。
所以, 在那種情況下,我們可以把input string的每一個(gè)字符的前邊都加上反斜杠 比如:
復(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
您可能感興趣的文章:
- JavaScript中兩個(gè)感嘆號(hào)的作用說(shuō)明
- 解釋&&和||在javascript中的另類(lèi)用法
- Javascript的&&和||的另類(lèi)用法
- PHP和javascript常用正則表達(dá)式及用法實(shí)例
- javascript常見(jiàn)用法總結(jié)
- javascript中的括號(hào)()用法小結(jié)
- JavaScript中的typeof操作符用法實(shí)例
- javascript中style.left和offsetLeft的用法說(shuō)明
- javascript中的self和this用法小結(jié)
- javascript特殊用法示例介紹
- javascript中2個(gè)感嘆號(hào)的用法實(shí)例詳解
相關(guān)文章
僅IE支持clearAttributes/mergeAttributes方法使用介紹
僅IE中HTMLElement元素具有clearAttributes/mergeAttributes方法,它們都是非標(biāo)準(zhǔn)的2012-05-05js, jQuery實(shí)現(xiàn)全選、反選功能
本文主要介紹了js, jQuery實(shí)現(xiàn)全選、反選功能的方法,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03JS實(shí)現(xiàn)超精簡(jiǎn)響應(yīng)鼠標(biāo)顯示二級(jí)菜單代碼
這篇文章主要介紹了JS實(shí)現(xiàn)超精簡(jiǎn)響應(yīng)鼠標(biāo)顯示二級(jí)菜單代碼,可實(shí)現(xiàn)針對(duì)鼠標(biāo)事件的響應(yīng)動(dòng)態(tài)修改頁(yè)面元素屬性的功能,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-09-09JavaScript中的函數(shù)聲明和函數(shù)表達(dá)式區(qū)別淺析
這篇文章主要介紹了JavaScript中的函數(shù)聲明和函數(shù)表達(dá)式區(qū)別淺析,本文總結(jié)的淺顯易懂,非常好的一篇技術(shù)文章,需要的朋友可以參考下2015-03-03js動(dòng)態(tài)添加onload、onresize、onscroll事件(另類(lèi)方法)
window 的 onload、onresize、onscroll 事件,跟其他的事件不一樣,它不能用 attachEvent 或 addEventListener 來(lái)添加于是本人想了一些另類(lèi)的方法,需要了解的朋友可以參考下2012-12-12