【前端学习笔记】Javascript中的正则表达式

复习字符串操作—————————————————————————–

indexOf 查找字符 返回位置
charAt  查找位置 返回字符
substring 获取字符窜
split     分割字符串

正则表达式的概念和写法—————————————————

正则 :也叫做规则,让计算机能够读懂人类的规则

正则都是操作字符串的。

正则的写法:
var re = /a/;      和数组字符串区分开来
var re = newRegExp('a');

【正则默认】 : 

    1.正则中是区分大小写的
    不区分大小写在正则后加 表示i (ignore)
    如var re = newRegExp('a','i');

    2.正则匹配成功就会结束,不会继续匹配,
    如果想全部查找就要加 标识g (global)

正则表达式的常用方法———————————————————————-

【test】 : 正则去匹配字符串,如果匹配成功返回true,否则返回false

test的写法 : 正则.test(字符串)



【search】 : 正则去匹配字符串,如果匹配成功就返回匹配成功的位置,
失败就返回-1

search的写法 : 字符串.search(正则)


【match】 : 正则去匹配字符串,如果匹配成功返回匹配成功的数组,
不成功则返回null

match的写法 : 字符串.match(正则)

【replace】 : 正则去匹配字符串,匹配成功的字符将被换成新的字符串

replace写法 : 字符串.replace(正则,新字符串) 
replace方法的第二个参数可以是字符串也可以是一个回调函数function(str){}
而这个函数的第一个参数 是从原字符串里匹配好的字符串。

匹配子项———————————————————————————-

【匹配子项】 : 小括号 () (还有另外一个意思:分组操作)

    把正则的整体叫做母亲

    优先合并小括号内的正则式,再合并所有小括号子项

    左边第一个小括号里的正则,叫第一个子项,第二个叫做第二个子项

    str.replace(re,function($0,$1,$2){});

    $0:母亲。$1:第一个孩子匹配的字符串。 $2:第二个孩子匹配的字符串。

    str.match(re) 在re没加 标识g的情况下,会返回母亲和每个子项组成的数组

量词————————————————————————————–

【量词】 : 匹配不确定的位置
    {4,7} : 最少出现4次,最多出现7次
    {4,} : 最少出现4次
    {4} : 正好出现4次

    + : 至少出现一次 {1,}

    ? : 0或1次{0,1}

    * : 至少出现0次{0,}

    | : 或  优先级最低

转义字符————————————————————————————–

【转义字符】 :加上\以后是另一个意思

    \s : 空格
    \S : 非空格
    \d : 数字
    \D : 非数字 
    \w : 字符  (字母、数字、下划线)
    \W : 非字符
    .  : 任意字符
    \. : .这个字符
    \* : *这个字符
    \b : 独立的部分 (\b代表起始、结束、空格)
    \B : 非独立的部分
    \1 : 重复的子项 (\1代表前面出现的第一个子项,\2代表第二个)
         当第一个子项代表的是多个可能的字符,\1的输出结果要和其一样。
         比如/\w\w/是任意两个字符,而/(\w)\1/是任意两个一样的字符 

    ^ : 正则的最开始位置,就代表起始
    $ : 正则的最结束位置,就代表结束

字符类————————————————————————————–

字符类 :一组相似的元素 [] 中括号的整体代表一个字符,
括号里的每个都可以作为整体的代表。想代表多个字符可以用[]+

排除 : ^ 如果^写在[]里面的话,就代表排除[]里的元素。
例如:[^abc]就代表除了a、b、c以外的字符

范围 : [a-z],代表从a到z所有的字母都能代替[a-z]。范围的顺序一定要从小到大

高级表单验证——————————————————————————–

匹配中文 : [\u4e00-\uu9fa5]

行首行尾空格 : ^\s*|\s*$

Email : ^\w+@[a-z0-9]+(\.[a-z]+){1,3}$

网址 : [a-zA-z]+:\/\/[^\s]*

QQ : [1-9][0-9]{4,9}

邮政编码 : [1-9]\d{5}

身份证号 : [1-9]\d{14}|[1-9]\d{17}|[1-9]\d{16}x (15位、18位、17位加x)

lastindex—————————————————————————

语法:RegExpObject.lastIndex
说明

该属性存放一个整数,它声明的是上一次匹配文本之后的第一个字符的位置。

上次匹配的结果是由方法 RegExp.exec() 和 RegExp.test() 找到的,它们都以
lastIndex 属性所指的位置作为下次检索的起始点。
这样,就可以通过反复调用这两个方法来遍历一个字符串中的所有匹配文本。

该属性是可读可写的。只要目标字符串的下一次搜索开始,就可以对它进行设置。
当方法 exec() 或 test() 再也找不到可以匹配的文本时,它们会自动把
lastIndex 属性重置为 0。


重要事项:不具有标志 g 和不表示全局模式的 RegExp 对象不能使用 lastIndex 属性。

提示:如果在成功地匹配了某个字符串之后就开始检索另一个新的字符串,需要手动地把这个属性设置为 0。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值