美文网首页
正则的拓展

正则的拓展

作者: keknei | 来源:发表于2017-07-05 22:51 被阅读12次

新增y修饰符

y修饰符跟g有点类似,但是仅仅是类似,y跟g不同的是,g是匹配到一个后,不管匹配到的字符后面紧跟着的有没有匹配到,都会继续匹配,但是y不一样,y会在匹配到的字符后面紧着匹配,如果没有匹配到,就会停止匹配,不会像g那样一直匹配下去

let reg1=/aa/g;
let reg2=/aa/y;
const str='aaa_aa_a';
console.log(reg1.exec(str));//["aa", index: 0, input: "aaa_aa_a"]
console.log(reg1.exec(str));//["aa", index: 4, input: "aaa_aa_a"]
console.log(reg1.exec(str));//null
console.log(reg2.exec(str));//["aa", index: 0, input: "aaa_aa_a"]
console.log(reg2.exec(str));//null

上面的例子我们可以看出使用y修饰符时,如果匹配不到的话,会返回null,exec这个方法返回的是一个数组,对应的aa是匹配到的结果,index是匹配的下标位置,input的是匹配的字符,

使用lastIndex,可以更好的说明y修饰符

let reg1=/aa/g;
let reg2=/aa/y;
const str='aaa_aa_a';
console.log(reg2.exec(str));//["aa", index: 0, input: "aaa_aa_a"]
reg2.lastIndex=4;//从下标4开始
const match=reg2.exec(str);
console.log(match);//["aa", index: 4, input: "aaa_aa_a"]
console.log(match.index);//4

lastIndex属性指定每次搜索的开始位置,y修饰符同样遵守lastIndex属性,但是要求必须在lastIndex指定的位置发现匹配。

下面我们看一下split、match加y修饰符方法的效果

let s='ororhellor world'
const reg1=/or/y;
const reg2=/or/g;
console.log(s.split(reg1));//["", "", "hellor world"]
console.log(s.split(reg2));//["", "", "hell", " w", "ld"]
console.log(s.match(reg1));//["or", index: 0, input: "ororhellor world"]
console.log(s.match(reg1));//["or", index: 2, input: "ororhellor world"]
console.log(s.match(reg2));//["or", "or", "or", "or"]
s='hello world';
console.log(s.match(reg1));//null
console.log(s.match(reg2));//["or"]
console.log(s.split(reg1));//["hello world"]

我们可以看出,split加上y修饰符正则,跟我们想像的一样,匹配不到,就不往后匹配了,直接把hello world返回回来了,match加上y修饰符正则搞得跟exec方法有点像,不是直接把全部的匹配完,而是得在调用一次,,,,,,表示好特么累啊,,

sticky、flags、source属性

let reg1=/[0-9]\d/yi;
let reg2=/[0-9]\d/gm;
console.log(reg1.sticky);//true
console.log(reg2.sticky);//false

let reg=/[a-z]/ygim;
console.log(reg.source);//[z-z]
console.log(reg.flags);/ygim/

sticky属性返回了正则的是否具有y修饰符,flags返回了正则的修饰符,source返回了正则的匹配。

真正做项目的时候,好像没什么卵用,but,大家还是要涨涨姿势的
</br>

OK,今天给大家介绍的正则的拓展,虽然不多,但是希望能帮助到大家。

继续咱们的惯例=>如果想学习更详细的资料,请狠狠的点击这里
</br>
</br>

相关文章

  • 正则的拓展

    新增y修饰符 y修饰符跟g有点类似,但是仅仅是类似,y跟g不同的是,g是匹配到一个后,不管匹配到的字符后面紧跟着的...

  • 正则表达式

    基础正则表达式 拓展正则表达式 贪婪与懒惰

  • es6

    3.1 const 3.2 解构赋值 3.3 正则拓展 3.4 字符串拓展 ES7提案 3.6 数值拓展 3.7 ...

  • 4、正则的拓展

    4 正则的拓展 #4.1 介绍 在ES5中有两种情况。 参数是字符串,则第二个参数为正则表达式的修饰符。 参数是正...

  • shell编程之正则表达式

    正则表达式在程序语言中很常见 有利于其他语言中正则表达式的学习 1.正则表达式 ?和()是拓展正则 若是以".$"...

  • 正则表达式 - 2017 - 完结篇

    ** 题记:接上回,我们说到了关于正则表达式的基本的语法,这次我们就来继续拓展正则表达式的内容,包括了正则表达式中...

  • iOS拓展-正则运算

    1. 正则运算意义 regular expression 描述了一种字符串匹配的模式,可以用来检查一个串是否含有某...

  • Markdown-富文本转换(2)

    上一节编写关于编写使用正则正则转换标题、图片链接,网页链接、代码块的例子,接下继续编写其拓展。Markdown-富...

  • 从贝叶斯到深度学习及各自优缺点

    正则化算法(Regularization Algorithms) 回归的拓展,会基于模型复杂性对其进行惩罚,它喜欢...

  • 正则实例拓展(环视特性)

    本篇主要介绍Perl(以及其他流派的正则)提供的简记法(shorthands),以及修改文本中使用的正则环视特性,...

网友评论

      本文标题:正则的拓展

      本文链接:https://www.haomeiwen.com/subject/lxkchxtx.html