摘要:元字符代表一类字符元类字符有或者的意思。里还可以有数字大小写字母。比如输出量词量词是用来修饰字符的。
元字符 [ ]
[ ] 代表一类字符(元类字符), [ ]有或者的意思,。比如[abc],意思就是a或b或c。 [ ]里还可以有数字.大小写字母。比如[0-9a-zA-Z]
var str="diauhvvdai"; var reg=str.replace(/[ha]/g,"xx"); console.log(reg);//输出dixxuxxvvdxxi量词 {}
量词是用来修饰字符的。
{m} m位数
{m,n} m位数-n位数
{m,} m及m以上位数
+ {1,} 1位及1位以上
* 任意
? 0或1位
var str="123 38658 395 38726 34324"; var reg=str.match(/d{2,5}/g); console.log(reg);//输出["123", "38658", "395", "38726", "34324"]尽可能匹配更多的字符(贪婪模式) console.log(/a?/.test(str));//输出true贪婪模式
贪婪模式
var str="123 38658 395 38726 34324"; var reg=str.match(/d{2,5}/g); console.log(reg);//输出["123", "38658", "395", "38726", "34324"]尽可能匹配更多的字符(贪婪模式)
非贪婪模式 (?)
var str="123 38658 395 38726 34324"; var reg1=/d{3,}?/g; console.log(str.match(reg1))分支 分组 引用
分支 | 或者的意思 [ab]相当于(a|b)
var str="dskj lsdk dslknv lksn"; var reg=str.match(/skj|sdk/g); console.log(reg);//输出["skj", "sdk"] var reg1=/dskj|lsdk/g; console.log(str.match(reg1));//输出["dskj", "lsdk"]
分组 ()
忽略分组 ?:
var str1=` 2017-08-25 hdbh-12-12 1234/11/21 2019/211/12 2134-12-122`;//模板字符串 var reg2=/(d{4})[-/](dd)(?:-|/)(d{2})[^0-9]/g; console.log(str1.match(reg2)); console.log(str1.replace(reg2,"$2月$3日$1年")); /* 输出["2017-08-25↵", "1234/11/21↵"] 08月25日2017年 hdbh-12-12 11月21日1234年 2019/211/12 2134-12-122 */
边界问题引用 $1.$2,... (引用的就是分组的内容)
上一个例子用的$1,$2,$3就是引用
^$ (整个字符串用^开头,用$结尾)
单词的边界 b
非单词的边界 B
/^d{11}$/ 手机号前瞻
正向前瞻 reg(?=assert) assert断言
反向前瞻 reg(?!assert)
var str="Hi Hello Hew Hz Hv"; var reg=/H(?=i|z)/g; console.log(str.replace(reg,"h"));//输出hi Hello Hew hz Hv var reg1=/H(?!e)/g; console.log(str.replace(reg1,"h"));//输出hi Hello Hew hz hv
###正则对象的属性
lastIndex 最后匹配的索引
reg.flags 修饰符(igm)
reg.global
reg.ignoreCase
reg.multiline
reg.source 正则里的内容
var str="ab dbn ubd"; var reg=/b/g; console.log(reg.test(str));//输出2 console.log(reg.lastIndex);//输出ture console.log(reg.test(str));//输出5 console.log(reg.lastIndex);//输出ture console.log(reg.test(str));//输出9 console.log(reg.lastIndex);//输出ture console.log(reg.test(str));//输出0 console.log(reg.lastIndex);//输出false console.log(reg.flags) //输出g 修饰符(igm) console.log(reg.global) //输出ture console.log(reg.ignoreCase) //输出false console.log(reg.multiline) //输出false console.log(reg.source) //输出b 正则里的内容正则表达式的使用
test 用来查看是否存在,有则输出ture,没有则输出false
exec 只找第一个
返回值:如果没有找到匹配返回null,如果找到则返回一个数组
返回的数组有三个属性,分别是input、index和lastIndex
complie 用来修改正则
var str="ab dbn ubd dsjh dskj"; var reg=/[a-z]+/g; console.log(reg.test(str));//输出ture console.log(reg.exec(str));//输出"dbn" reg.compile("[a-z]+","i"); console.log(str.search(reg));//输出0字符串的方法
search("")//结果为>-1则有该字符串,为-1时则没有
split("-")//"2017-8=24" 结果为["2017","8","24"]
match 返回值:如果没有找到匹配返回null,如果找到则返回一个数组
返回的数组有三个属性,分别是input、index和lastIndex,input包含了查找的字符串,index属性包含了整个被查找字符串中被匹配的子字符串的位置,lastIndex属性中包含了最后一次匹配中最后一个字符的下一个位置
replace("is","Is")//将"is"替换成"Is",只能替换1次,想替换n次,则写n次。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/84924.html
摘要:之前写过一篇天学通前端开发,内容主要讲的就是前端学习路径,今天再来写一篇零基础的学习路径,希望能帮编程零基础的前端爱好者指明方向。十框架三选一,零基础的初学者强烈推荐,如果是后台转前端推荐,如果技术型前端,推荐。 之前写过一篇26天学通前端开发,内容主要讲的就是前端学习路径,今天再来写一篇零基础的JavaScript学习路径,希望能帮编程零基础的前端爱好者指明方向。 一、开发环境和Ja...
摘要:在他的重学前端课程中提到到现在为止,前端工程师已经成为研发体系中的重要岗位之一。大部分前端工程师的知识,其实都是来自于实践和工作中零散的学习。一基础前端工程师吃饭的家伙,深度广度一样都不能差。 开篇 前端开发是一个非常特殊的行业,它的历史实际上不是很长,但是知识之繁杂,技术迭代速度之快是其他技术所不能比拟的。 winter在他的《重学前端》课程中提到: 到现在为止,前端工程师已经成为研...
摘要:在他的重学前端课程中提到到现在为止,前端工程师已经成为研发体系中的重要岗位之一。大部分前端工程师的知识,其实都是来自于实践和工作中零散的学习。一基础前端工程师吃饭的家伙,深度广度一样都不能差。开篇 前端开发是一个非常特殊的行业,它的历史实际上不是很长,但是知识之繁杂,技术迭代速度之快是其他技术所不能比拟的。 winter在他的《重学前端》课程中提到: 到现在为止,前端工程师已经成为研发体系...
阅读 1985·2021-09-09 09:33
阅读 1115·2019-08-30 15:43
阅读 2669·2019-08-30 13:45
阅读 3308·2019-08-29 11:00
阅读 859·2019-08-26 14:01
阅读 3571·2019-08-26 13:24
阅读 481·2019-08-26 11:56
阅读 2691·2019-08-26 10:27