正则表达式

正则表达式

    • 介绍与强调
    • 关于元字符
    • 小练习
    • 要求
    • 常用方法补充

学习资源推荐

介绍与强调

  • 按照一定的规则组成的一个表达式(一般元字符和限定符)
  • 作用主要是匹配字符串的,常用于表单验证
  • 定义方式
    • 通过构造函数创建对象 var reg=new RegExp(/[0-9]/);
    • 字面量的方式创建对象 var reg=/[0-9]/;
  • 非严格模式下,匹配一项就是匹配全部
  • 严格模式 /^…$/ ,要有开始和结束限定符
  • 正则表达式必须分清是否为严格模式
  • 默认匹配一项后停止,全局匹配用g
  • 忽略大小写用i

关于元字符

元字符 含义 案例
. 除了\n以外的任意一个单个字符 abc123@#$等等
[] 范围 [a-z],小写字母中的任意一个,把正则表达式中元字符的意义干掉,原样输出[5]就是数字5
* 0-多次 [a-z][0-9]*,任意一个小写字母,后边跟着0个或多个,a1,a123,b1,b都匹配
+ 1-多次 [a-z][3]+ 小写字母一个后面最少一个3,或者多个3,如c3,cc33,abcddd3333
? 0-1次 [2][a-z]?,数字2后边出现0或1个任意小写字母
() 分组,或者提升优先级 这个么啥说的
| 或者 [a-z]|[0-9],任意一个小写字母或者任意一个数字
{0,} 和*一样 参考*
{1,} 和+一样 参考+
{0,1} 和?一样 参考?
\d 数字中的一个 123467890
\D 非数字 与\d相反
\s 空白符 比如空格,tab键
\S 非空白符 与\s相反
\W 特殊符号 @#等
\w 非特殊符号 典型的是下划线 _
^ 取反,开始 [^0-9],非数字,与\D一样,与\d相反,/^5/,以5开始,注意^所在位置
$ 结束 /[9]$/,以9结束
补充 中文名字 /^[\u4e00-\u9fa5]{2,6}$/

小练习

  • 一定要注意区分是否为严格模式,不然会懵逼的
  • console.log(/./.test(“除回车换行以外的任意字符”));//true
  • console.log(/.*/.test(“0个到多个”));//true
  • console.log(/.+/.test(“1个到多个”));//true
  • console.log(/.?/.test(“哈哈”));//true
  • console.log(/[0-9]/.test(“123456”));//true
  • console.log(/[a-z]/.test(“lengyuexin”));//true
  • console.log(/[A-Z]/.test(“Helloworld”));//true
  • console.log(/[a-zA-Z]/.test(“杨梦言”));//false
  • console.log(/[0-9a-zA-Z]/.test(“1jpg”));//true
  • console.log(/b|(are)/.test(“abre”));//true
  • console.log(/[a-z]{2,3}/.test(“qwezxc”));//true

要求

  • 可以不会自己写,但是要能做到会改别人的
  • 需要时百度即可,自己会当然最好
  • 使用强烈建议用严格模式+字面量定义方式

常用方法补充

  • 常用方法之test(),返回true或false
    在这里插入图片描述

  • 常用方法之match(),返回匹配成功的数据、g表示全局匹配
    在这里插入图片描述

  • 常用方法之replace(),替换匹配数据
    在这里插入图片描述

  • 忽略大小写的全局匹配
    在这里插入图片描述

  • 学习资源推荐

  • 正则小练习

你可能感兴趣的:(正则表达式)