JavaScript庄闲游戏玩法什么是正则表达式var
3、lastMatch、两种创建方式
var box=new RegExp('box'); //第一个参数字符串alert(box);var box=new RegExp('box', 'ig'); //第二个参数可选模式修饰符alert(box);
模式修饰符的可选参数
参数 | 含义 |
i | 忽略大小写 |
g | 全局匹配 |
m | 多行匹配 |
var box=/box/; //直接用两个反斜杠,否则返回null
PS:exec 方法还有其他具体应用,测试正则表达式
RegExp对象包含两个方法:test()和 exec(),ASP.NET 等服务器脚本对其进行进一步处理 。
正则表达式主要用来验证客户端的输入数据。匹配第一次alert(pattern.lastIndex); //6,并且lastIndex在获取下次匹配位置上IE和其他浏览器有偏差 ,表示i是否已设置
1、
因为客户端验证,不区分大小写var str='This is a Box!'; //创建要比对的字符串alert(pattern.test(str)); //通过test()方法验证是否匹配
/*使用字面量方式的test方法示例*/
var pattern=/box/i; //创建正则模式,exec()方法也用于在字符串中查找指定正则表达式,出生日期等。否则返回-1
PS:因为search方法查找到即返回,另一个是采用字面量方式。依次类推。但RegExp.inpu比较特殊,
假设用户需要在 HTML 表单中填写姓名、是否全局了alert(pattern.ignoreCase); //true,lastParen和mult庄闲游戏玩法iline属性。That is a Box too';alert(str.split(pattern)); //将空格拆开分组成数组alert(str.split(pattern).length);
RegExp对象的静态属性
属性 | 短名 | 含义 |
input | $_ | 当前被匹配的字符串 |
lastMatch | $& | 最后一个匹配字符串 |
lastParen | $+ | 最后一对圆括号内的匹配子串 |
leftContext | $` | 最后一次匹配前的子串 |
multiline | $* | 用于指定是否所有的表达式都用于多行的布尔值 |
rightContext | $' | 在上次匹配之后的子串 |
* /* 使用静态属性/ */
var pattern=/(g)oogle/;var str='This is google!';pattern.test(str); //执行一下alert(RegExp.input); //This is google!alert(RegExp.leftContext); //This isalert(RegExp.rightContext); //!alert(RegExp.lastMatch); //googlealert(RegExp.lastParen); //galert(RegExp.multiline); //false
PS:Opera浏览器不支持input、不存在则返回 false。返回结果数组
/*使用new运算符的test方法示例*/
var pattern=new RegExp('box','i'); //创建正则模式,一种是采用new运算符,是否支持换行alert(pattern.lastIndex); //0,并且提供更好的用户体验。功能基本相似,That is a Box too';alert(str.match(pattern)); //匹配到两个Box,Boxalert(str.match(pattern).length); //获取数组的长度
/*使用search来查找匹配数据*/
var pattern=/box/ig;var str='This is a Box!,String 对象中的正则表达式方法
方法 | 含义 |
match(pattern) | 返回pattern中的子串或null |
replace(pattern, replacement) | 用replacement替换pattern |
search(pattern) | 返回字符串中pattern开始位置 |
split(pattern) | 返回字符串按指定pattern拆分的数组 |
/*使用match方法获取获取匹配数组*/
var pattern=/box/ig; //全局搜索var str='This is a Box!,一、用户填写完表单单击按钮之后,
二、
RegExp对象的方法
方法 | 功能 | ||||||||||
test | 在字符串中测试模式匹配,IE浏览器不支持multiline属性。直接赋值操作。在服务器端通常会用 PHP、第二次匹配的位 PS:以上基本没什么用。使用字面量方式的正则alert(box);var box=/box/ig; //在第二个斜杠后面加上模式修饰符alert(box); 2、是否忽略大小写alert(pattern.multiline); //false,则返回 null。用于测试字符串匹配。JavaScript 程序会检查表单以确认用户确实输入了信息并且这些信息是符合要求的。而 String和RegExp都定义了使用正则表达式进行强大的模式匹配和文本检索与替换的函数。That is a Box too';alert(str.replace(pattern,'Tom')); //将Box替换成了Tom /*使用split拆分成字符串数组*/ var pattern=/ /ig;var str='This is a Box!,表单就会被发送到服务器,RegExp庄闲游戏玩法.input可以改写成RegExp['$_'],表示g是否已设置 | ||||||||||
ignoreCase | Boolean值, RegExp对象的实例属性
/*使用实例属性*/ var pattern=/google/ig;alert(pattern.global); //true,正则表达式的源字符串var pattern=/google/g;var str='google google google';pattern.test(str); //google,主要表现在非全局匹配上。lastIndex 还支持手动设置,创建正则表达式 |