码迷,mamicode.com
首页 > Web开发 > 详细

js高级 6

时间:2019-01-14 21:33:40      阅读:206      评论:0      收藏:0      [点我收藏+]

标签:意义   技术   换行   方法   ber   就是   ret   函数   改变   

 

1.var reg=/./ var reg=/\./

  前者代表任意一个字符而后者代表这个字符串中得有一个.

2.?号的使用

 如果是单独的一个字符后面带?var reg=/\d?/ /n?/

 代表一个或0个这个字符的出现

 如果是量词+和*,{2,}后面带?取消正则的贪婪性 在捕获阶段

 技术分享图片

3.捕获

  1.普通捕获exec() match()

  普通捕获有懒惰性,给正则添加一个修饰符g可以解决,match是将所有捕获的内容放在一个数组中并返回。Match就是对exec的一个简单的封装

  2.分组捕获 捕获的方法还是exec和Match

  正则在结构上发生的变化,加()

  var reg=/(a)(b)/

  exec()和match()在非全局下分组捕获是相同的,字捕获的过程中即捕获大正则里的内容也捕获分组中的内容并都返回

  技术分享图片技术分享图片

  exec()和Match()在全局下的分组捕获是不一样的,exec()不变。但是match()只捕获大正则里的内容

  技术分享图片技术分享图片

  3.分组捕获的优势

    1.可以提升优先级  2.可以捕获引用

  \1代表分组1里面的内容    \2代表分组2里面的内容

  前提是分组必须在引用之前,如果\2在分组的前面代表普通的表达式???

   分组的结果存在正则类RegExp的$number属性下

  \1和RegExp.$1二者都是分组引用

  \1只能使用在正则表达式里面,RegExp.$1 可以外面使用。都是在捕获完成的条件下

  4.在捕获的过程中怎样取消捕获分组中的类

    在分组的前面加上?:就好了

    ?:和?=的区别

      ?:取消捕获分组中的内容的

      ?= a(?=5)

       技术分享图片

4.replace细说

  replace是字符串的一个方法,他有两个参数,用后者将前者替换掉,并返回一个新的字符串但是没有改变原来的字符串

  1.如果第一个参数是字符串,只改变一次

  2.如果第一个参数是正则,捕获一次改变一次

  3.如果第二个参数是匿名函数,每捕获一次这个匿名函数会执行一次,return的是什么,那就替换成什么。这个匿名函数的arguments有三个元素

  技术分享图片

  正则详细讲解

  1.每一个正则都是由元字符和修饰符组成

  2.元字符 在//之间有特殊意义得字符

  3.具有特殊意义得元字符

    1.\转义字符,转移后面字符所代表的含义

    2.^以某一个元字符开始

    3.$以某一个元字符结尾

    4.\n匹配一个换行符

    5. .除了\n以外的任意一个字符

    6.()分组,把一个大正则划分为几个小正则

    7.X|y x或y中的一个

    8.[xyz],x或者y或者z三者中的一个

    9.[^xyz]^读作v

    var reg=/^\d$/  只能是一个0-9之间的数字

    技术分享图片是因为^和$不占用位置只有\d占位置

4.代表出现次数的量词的元字符

  1.*代表出现0次

  2.+代表出现1到多次

  3.?出现0都1词

  4.{n}出现n词

  5.{n,}出现n到多次

  6.{n,m}出现n到m次

规律

[]

1.在[]中出现的所有字符都是代表本身意思的字符

2.[.]就是本身.[+]代表的就是+本身

3.[]里面不识别双位数[12]不识12是1或者2

  [12-68]代表的是1或者2-6中的一个或者8

案例1有效数字的正则

  0.4 12.0 12 +12 -12 09

  var reg=/^[+-]?(\d([1-9]\d+))(\.d+)$/

   |的混乱

  Reg=/^18|19$/和/^(18/19)$/

  前者表达的优先级特别多

  1.可以是以1开头以9结尾的字符串189 119 119等

   2.也可理解为以18开头或以19结尾 181 119 等

   而后者只有一种就是18或者19

  分组提升了优先级

  分组的第一个作用就是改变优先级

 

js高级 6

标签:意义   技术   换行   方法   ber   就是   ret   函数   改变   

原文地址:https://www.cnblogs.com/LXW2002326/p/10268900.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!