正则-RegExp

正则-RegExp

  正则,是一条规则,用于检验字符串格式,目标就是字符串;

  只要是表单提交的数据都是字符串

  定义:

    1,var reg=/格式/

    2,var reg=new regexp()

  方法:

    两大功能---匹配,test()  成功就是true,反之false;

         捕获,exec()  成功就会拿出来,没有就是null;

  修饰符:

    i  忽略大小写

    g  全局匹配

    m  多行匹配

  如何使用修饰符:

    1,var reg=/hello/gi    字面量方式

    2,var reg=new regexp(“hello”g)    实例方式

  正则的方括号:

    [abc]  代表查找方括号中的任何字符

    [^abc]  代表查找不在方括号中的字符

    [0-9]  代表查找0-9之间的数字

    [a-z]  代表查找小写a到小写z之间

    [A-Z]  代表查找大写A到大写Z之间

    [A-z]  代表查找大写Z到小写z之间

    (red|blue|black)  查找任何指定的选项

  正则的元字符:

    .  代表单个字符(任意字符,数字字母下划线空格等)

    \w  代表单词字符(数字字母下划线)

    \W  代表非单词字符

    \d  代表数字

    \D  代表非数字

    \s  代表空白字符

    \S  代表非空白字符

    \b  代表单词边界

    \B  代表非单词边界

  正则的量词:

    n+       代表至少一个n的字符

    n*         代表0个或多个n(添加相邻元素)

    n?         代表0个或一个n(添加相邻元素,0个或一个全部拿走)

    n{x}        包含x个n

    n{x,}       包含至少x个n

    n{x,y}     包含大于等于x,小于等于y个n

    n$      以n结尾

    ^n      以n开头

    ?=n     指定字符后面紧跟

字符串方法:(跟正则有关的)

  1,match()查找一个或多个和正则相匹配的,有就返回的是查找的结果,没有就null

  2,search()匹配和正则相同的字符,有就返回索引,没有就-1

  3,replace()匹配和正则相同的幷替换掉,返回的是换之后的

正则的理解:

  1,贪婪性:

    每一次匹配都是按最长的出结果,这种功能叫正则的贪婪性

  2,懒惰性:

    每一次在exec()中捕获的时候,只捕获第一次匹配的内容,而不再往下捕获了,这个叫正则的懒惰性;每一次捕获的位置都是从0开始

如何解决正则的懒惰性?修饰符g

正则的实例对象reg上有一个lastindex属性,他是正则捕获的起始位置

如何解决正则的贪婪性?在元字符量词后面加问号

分组捕获:

  正则带(),数分组个数的时候从左往右

  var reg=/(a)(b)/

  相当于大正则里面带了两个小正则  第一组(a)第二组(b)

  分组捕获作用

    1,改变优先级  2,分组引用  \1  \2

    \1  代表和第一个分组出现一模一样的内容

    \2  代表和第二个分组出现一模一样的内容

    var reg=/(\w)\1(\w)\2/

    var st="ssdd"

    var s=reg.test(st)

    console.log(s)    //true

    正则reg中的规则第一个是一个分组;且是一个单词字符

            第二个是一个分组引用;要求和第一组一模一样

  分组捕获:

    前提是正则存在分组,不仅把大正则内容捕获到,把小正则内容也捕获到

  如何解除分组捕获

    在这个分组前面加问号冒号?:

 

posted @ 2018-12-21 17:15  黑太阳-  阅读(200)  评论(0编辑  收藏  举报