正则表达式一

工欲善其事,必先利其器,JQ源码中充斥的大量的正则表达式,我准备根据李炎恢老师的正则表达式的讲解,
写一篇有关正则表达式的笔记!不墨迹,直接进入正题!

ECMAScript 的 RegExp 类 表示正则表达式
正则表达式在JQ中被大量运用,主要是为了检索字符串,进行匹配
创建正则表达式

var box=new RegExp('box');
//当然后面还可以传入一个参数,是用来确定修饰正则验证时的规则
//字面量方式的正则,最为常用
var box=/box/
//如果传参的话
var box=/box/igm
  1. i 忽略大小写
  2. g 全局匹配,否则匹配到第一个停止
  3. m 多行匹配,字符串有很多行,不加m只匹配第一行

如何匹配呢,RegExp 对象包含两个方法:test()和 exec()。**test() 方法在字符串中查找是否存在指定的正则表达式并返回布尔值,如果存在则返回 true,不存在则返回 false。exec()方法也用于在字符串中查找指定正则表达式,如果 exec()方法执行成功,则返回包含该查找字符串的相关信息数组。如果执行失败,则返回 null。

//test方法
var pattern=/box/i;
var str="this is a BOX"
alert(pattern.test(str));//false
alert(/box/i.test('This is a Box!')); //一条语句判断
//exec方法,还有其他应用,下面再说
var pattern= /box/i;
var str ='Thisis aBox!'; 
alert(pattern.exec(str));//返回一个box,但这个不是一个字符串,有就返回数组的值,没有就null
alert(typeof pattern.exec(str))//object是一个对象,数组也是对象,

下面说一下正则中,字符串正则的表达方法,因为String正则表达式的方法
分别是match,replace,search,sp四种方法,下面一一举例

search

var pattern=/box/ig;//否则第一个box就停止了
var str ='This is a Box!,That is a box too';
alert(str.search(pattern));//将所有组成数组返回//Box,box

search

var pattern=/box/i;
var str ='This is a Box!,That is a box too';
alert(str.search(pattern));//10,第一个位置为0,不会匹配到第二个,第一个就停止

replace

var pattern=/box/ig;//开启全局可以替换全部的Box
var str ='This is a Box!,That is a box too';
alert(str.replace(pattern,'Tom'));//返回替换后的字符串This is a Tom!,That is a Tom too
var pattern=/!/ig;//用!分割
var str ='This is a Box!,That is a box too';
alert(str.split(pattern));//This is a Box,That is a box too, 还有一个空的

RegExp对象的静态属性 其中实际很少使用,在书中也没找到一些有关静态的用法

var pattern= /(g)oogle/; 
var str ='Thisis google!'; 
pattern.test(str);//必须要执行,否则后面的属性就没有

//input显示当前匹配的字符串 可以用$_代替
alert(RegExp.input); //This is google
RegExp['$_']//这是改写
//最后一次匹配的字串  $` 
alert(RegExp.leftContext); //This is
RegExp['$`']
//在上一次匹配后的字串 $'
alert(RegExp.rightContext); //!
RegExp['$']
//最后一个匹配的字符串 ,$&
alert(RegExp.lastMatch);//google

//最后一对圆括号内的匹配字串  $+
alert(RegExp.lastParen); //g

//用于指定是否所有的表达式都用于多行的布尔值  $*
alert(RegExp.multiline); ///false

//要注意的是:Opera 不支持 input、lastMatch、lastParen 和 multiline 属性。IE不支持 multiline 属性。 

当然还有实例属性,用的也很少,都是一些检验某些属性是否存在的

var pattern= /google/ig;
alert(pattern.global); //true,是否全局了
alert(pattern.ignoreCase); //true,是否忽略大小写
alert(pattern.multiline); //false,是否支持换行
alert(pattern.source); //google,正则表达式的源字符串
var pattern= /google/g; varstr ='googlegoogle google'; pattern.test(str); //google,匹配第一次 alert(pattern.lastIndex); //6,第二次匹配的位
PS:以上基本没什么用。并且 lastIndex 在获取下次匹配位置上 IE 和其他浏览器有偏差, 主要表现在非全局匹配上。lastIndex 还支持手动设置,直接赋值操作。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小疯疯0413

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值