RegExp 随笔 JavaScript RegExp 对象
|
概述 RegExp 的构造函数创建了一个正则表达式对象,用模式来匹配文本。 有关正则表达式介绍,请阅读JavaScript指南中的正则表达式章节。 语法 文字和构造符号是可能的: 参数 pattern g
/ab+c/i;
new RegExp('ab+c','i');
new RegExp(/ab+c/,'i');
当表达式被赋值时,字面量形式提供正则表达式的编译(compilation)状态,当正则表达式保持为常量时使用字面量。例如当你在循环中使用字面量构造一个正则表达式时,正则表达式不会在每一次迭代中都被重新编译(recompiled)。 当使用构造函数创造正则对象时,需要常规的字符转义规则(在前面加反斜杠 )。比如,以下是等价的:
var re = new RegExp("w+");
var re = /w+/;
以字面量定义正则表达式 var pattern1 = /at/g; //匹配字符串中所有at var pattern2 = /[bc]at/i; //匹配第一个“bat”或“cat”,不区分大小写 var pattern3 = /.at/gi; //全局匹配以.at“结尾”的三个字符。不区分小写 模式中使用的所有元字符都必须转义。正则表达式中的元字符包括:([{^$|?*+.}]) var pattern4 = /[bc]at/i; //匹配第一个“[bc]at”,不区分大小写 使用RegExp构造函数,接受2个参数,参数1:要匹配的字符串模式,参数2:可选的标志行为
var pattern5 = new RegExp("[bc]at","i");
注:因为RegExp构造函数的模式参数都是字符串,所以在某些情况下要对字符串进行双重转义。所有元字符必须双重转义 例: 注:使用字面量和实例化创建正则表达式不一样,字面量始终会共享同一个RegExp实例(ECMAScript3)。使用构造函数创建的每一个新的RegExp实例都是一个新实例。 RegExp实例属性 console.log(pattern5.global); //false 是否设置了g标志 console.log(pattern5.ignoreCase); //true 是否设置了i标志 console.log(pattern5.multiline); //false 是否设置了m标志 console.log(pattern5.lastIndex); //0 开始搜索下一个匹配项的起始位置 console.log(pattern5.source); //[bc]at 正则表达式的字符串表示 继承属性 console.log(pattern5.toString()); // /[bc]at/i 正则表达式的字面量表示 console.log(pattern5.toLocaleString()); // /[bc]at/i 正则表达式的字面量表示 console.log(pattern5.valueOf()); // /[bc]at/i 正则表达式的字面量表示 RegExp实例方法
var text = "huang jin liang shi ge hao ren";
var pattern6 = new RegExp("huang( jin liAng( shi ge hao ren)?)?","i");
var matches = pattern6.exec(text);
console.log(matches);
//[ 'huang jin liang shi ge hao ren',// ' jin liang shi ge hao ren',// ' shi ge hao ren',// index: 0,// input: 'huang jin liang shi ge hao ren' ]
var text1 = "cat,bat,sat";
var pattern7 = new RegExp(".at")
var matches1 = pattern7.exec(text1);
console.log(matches1); //cat
var pattern8 = new RegExp(".at","gm");
var matches2 = pattern8.exec(text1);
console.log(matches2); //cat
var matches3 = pattern8.exec(text1);
console.log(matches3); //bat
var matches4 = pattern8.exec(text1);
console.log(matches4); //sat
var matches5 = pattern8.exec(text1);
console.log(matches5); //null
方法二:test(),接受一个参数,既应用模式字符串。该模式与该参数匹配的情况下返回true,反之false
var text2 = "000-00-0000";
var pattern9 = new RegExp("d{3}-d{2}-d{4}");
console.log(pattern9.test(text2))
console.log(text2);
if (pattern9.test(text2)) {
console.log("匹配成功");
} else {
console.log("匹配失败");
}
构造函数属性(某些浏览器不支持) 在ECMAScript局限性 刚发现一个js中匹配多行的方法 <script> var s = "Please yesnmake my day!"; alert(s.match(/yes.*day/)); // Returns null alert(s.match(/yes[^]*day/)); // Returns 'yesnmake my day' </script> 可惜了,editplus不能用,很多时候还是使用dw比较方便。 (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
