javascript中expression的用法

小哥我最近在学习javaScript, 学到regular expression的时候见知识点有些杂乱,所以特别写篇博客做个总结。

定义

在javascript里定义reg exp有两种方法:

1) 用new exp : var exp1 = new exp("abc");

2) 直接在两个/中间放pattern: var exp2 = /abc/;  //注意。。没有双引号哟, 加了就成string了


特殊字符

目测特殊字符和perl的是一样的。。直接拿来用就好

\dDigit characters
\wAlphanumeric characters (“word characters”)
\sWhitespace characters (space, tab, newline, and similar)
\DCharacters that are not digits
\WNon-alphanumeric characters
\SNon-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是一样一样一样的。。 这个表很好。。小哥我一直喜欢用

GreedyReluctantPossessiveMeaning
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





                
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
switch语句是JavaScript的一种条件语句,它根据一个表达式的值,将控制转移到匹配该值的case语句。下面是switch语句的基本语法: ``` switch(expression) { case value1: // 当 expression 与 value1 匹配时执行的代码 break; case value2: // 当 expression 与 value2 匹配时执行的代码 break; ... default: // 当所有 case 都不匹配时执行的代码 } ``` 其expression是需要进行匹配的表达式,value1、value2等则是需要进行匹配的值。当expression和某个value匹配时,就会执行该case下面的代码。如果没有任何一个case匹配成功,则会执行default下面的代码。 下面是一些switch语句的常见使用场景: 1. 多个if语句的替代方案 使用多个if语句时,代码会变得冗长,而使用switch语句则可以使代码更加简洁清晰。 ``` if (value === 'a') { // ... } else if (value === 'b') { // ... } else if (value === 'c') { // ... } // 等价于 switch (value) { case 'a': // ... break; case 'b': // ... break; case 'c': // ... break; } ``` 2. 状态判断 在某些情况下,我们需要根据某个状态来执行相应的操作,这时使用switch语句就非常方便。 ``` switch (state) { case 'loading': showLoading(); break; case 'success': showSuccess(); break; case 'error': showError(); break; } ``` 3. 枚举值判断 枚举类型在JavaScript并不存在,但是我们可以用对象模拟枚举类型。这种情况下,使用switch语句就可以方便地判断枚举类型的值。 ``` const Colors = { RED: 0, GREEN: 1, BLUE: 2 }; switch (color) { case Colors.RED: // ... break; case Colors.GREEN: // ... break; case Colors.BLUE: // ... break; } ``` 总之,switch语句是一种非常常用的条件语句,在JavaScript有着广泛的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值