javascript中expression的用法整理_javascript技巧
程序员文章站
2022-04-19 16:25:45
...
小哥我最近在学习javaScript, 学到regular expression的时候见知识点有些杂乱,所以特别写篇博客做个总结。
定义
在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 所以是数字
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。具体用法不在这里一一列出,请参考
点击打开链接
动态生成reg expression
当你想要用在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 所以是数字
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是一样一样一样的。。 这个表很好。。小哥我一直喜欢用
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。具体用法不在这里一一列出,请参考
点击打开链接
动态生成reg expression
当你想要用在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中跨域调用Flash的方法_javascript技巧
-
js中匿名函数的N种写法_javascript技巧
-
JavaScript中的this关键字介绍与使用实例_javascript技巧
-
JS中Iframe之间传值的方法_javascript技巧
-
JavaScript在XHTML中的用法详解_基础知识
-
JavaScript中this的用法实例分析
-
javascript中文本框中输入法切换的问题_javascript技巧
-
JGrid中拖动改变列宽的脚本 原型_javascript技巧
-
让多个输入框中的内容同时变化的js代码_javascript技巧
-
JS中Iframe之间传值的方法_javascript技巧