RegExp 随笔 JavaScript RegExp 对象_正则表达式

概述

RegExp 的构造函数创建了一个正则表达式对象,用模式来匹配文本。

有关正则表达式介绍,请阅读JavaScript指南中的正则表达式章节。

语法

文字和构造符号是可能的:
/pattern/flags new RegExp(pattern [, flags])

参数

pattern
正则表达式的文本
flags
如果指定,标志可以具有以下值的任意组合:

g
全局匹配
i
忽略大小写
m
多行;让开始和结束字符(^ 和 $)工作在多行模式工作(例如,^ 和 $ 可以匹配字符串中每一行的开始和结束(行是由 \n 或 \r 分割的),而不只是整个输入字符串的最开始和最末尾处。
u
Unicode。把模式当作Unicode代码点(code points)的序列。
y
黏度; 在目标字符串中,只从正则表达式的lastIndex属性指定的显示位置开始匹配(并且不试图从任何之后的索引匹配)。
描述
有两种方法可以创建一个正则对象:字面量和构造函数。要表示字符串,字面量形式不使用引号,而传递给构造函数的参数使用引号。下面表达式创建相同的正则表达式:

/ab+c/i;
new RegExp('ab+c', 'i');
new RegExp(/ab+c/, 'i');

当表达式被赋值时,字面量形式提供正则表达式的编译(compilation)状态,当正则表达式保持为常量时使用字面量。例如当你在循环中使用字面量构造一个正则表达式时,正则表达式不会在每一次迭代中都被重新编译(recompiled)。
而正则表达式对象的构造函数,如 new RegExp('ab+c') 提供了正则表达式运行时编译(runtime compilation)。如果你知道正则表达式模式将会改变,或者你事先不知道什么模式,而是从另一个来源获取,如用户输入,这些情况都可以使用构造函数。
从ECMAScript 6开始,当第一个参数为正则表达式而第二个标志参数存在时,new RegExp(/ab+c/, 'i')不再抛出TypeError (“当从其他正则表达式进行构造时不支持标志”)的异常,取而代之,将使用这些参数创建一个新的正则表达式。

当使用构造函数创造正则对象时,需要常规的字符转义规则(在前面加反斜杠 \)。比如,以下是等价的:

var re = new RegExp("\\w+");
var re = /\w+/;

以字面量定义正则表达式
var expression = /pattern/ flags;
pattern 部分可以是任何简单或复杂的正则表达示
flage 标明正则表达式的行为 1.g:全局模式,不会在发现第一个匹配项后停止 2.i:不区分大小写模式 3.m:多行模式
例:

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构造函数的模式参数都是字符串,所以在某些情况下要对字符串进行双重转义。所有元字符必须双重转义

例:
字面量        等价字符串
/\[bc\]at/      "\\[bc\\]at"
/\.at/        "\\.at"
/name/\age/    "name\\/age"
/\d.\d{1,2}/    "\\d.\\d{1,2}"
/\w\\hello\\123/ "\\w\\\\hello\\\\123"

注:使用字面量和实例化创建正则表达式不一样,字面量始终会共享同一个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实例方法
方法一:exec(),接受一个参数,既应用模式字符串。返回返回包含第一个匹配项信息的数组,在没有的情况下返回null,返回的数组实例包含两个属性index(匹配项在字符中的位置)和input(应用正则的字符串)。

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("匹配失败");
}

构造函数属性(某些浏览器不支持)
长属性名    短属性名 说明
input      $_    最近一次要匹配的字符串
lastMatch    $&    最近一次匹配项
lastParen    $+    最近一次捕获组
leftContext    $`    input字符串中lastMatch之前的文本
multiline    $*    布尔,是否是多行模式
rightContext $'    input字符串中lastMatch之后的文本
        $1~$9 分别用于存储第几个捕获组

在ECMAScript局限性
1.匹配字符串开始和结束的\A和\Z锚
2.向后查找
3.并集和交集类
4.原子组
5.Unicode支持(单个字符除外)
6.命名捕获组
7.s和x匹配模式
8.条件匹配
9.正则表达式注释

刚发现一个js中匹配多行的方法

<script>
var s = "Please yes\nmake my day!";
alert(s.match(/yes.*day/));
// Returns null
alert(s.match(/yes[^]*day/));
// Returns 'yes\nmake my day'
</script>

可惜了,editplus不能用,很多时候还是使用dw比较方便。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索RegExp
正则表达式regexp、js正则表达式regexp、regexp tcl正则表达式、regexplike正则表达式、javascript regexp,以便于您获取更多的相关知识。

时间: 2024-09-17 19:43:42

RegExp 随笔 JavaScript RegExp 对象_正则表达式的相关文章

RegExp 随笔 JavaScript RegExp 对象

概述 RegExp 的构造函数创建了一个正则表达式对象,用模式来匹配文本. 有关正则表达式介绍,请阅读JavaScript指南中的正则表达式章节. 语法 文字和构造符号是可能的: /pattern/flags new RegExp(pattern [, flags]) 参数 pattern 正则表达式的文本 flags 如果指定,标志可以具有以下值的任意组合: g 全局匹配 i 忽略大小写 m 多行;让开始和结束字符(^ 和 $)工作在多行模式工作(例如,^ 和 $ 可以匹配字符串中每一行的开始

共享日常收集JS正则表达式(JavaScript regular expression)_正则表达式

RegExp直接量和对象的创建 就像字符串和数字一样,程序中每个取值相同的原始类型直接量均表示相同的值,这是显而易见的.程序运行时每次遇到对象直接量(初始化表达式)诸如{}和[]的时候都会创建新对象.比如,如果在循环体中写var a = [],则每次遍历都会创建一个新的空数组.正则表达式直接量则与此不同,ECMAScript 3规范规定,一个正则表达式直接量会在执行到它时转换为一个RegExp对象,同一段代码所表示正则表达式直接量的每次运算都返回同一个对象.ECMAScript 5规范则做了相反

深入探讨JavaScript String对象_基础知识

String 字符串对象 1. 介绍 String 对象,对字符串进行操作,如:截取一段子串.查找字符串/字符.转换大小写等等. 2. 定义方式 2.1 new String(Value) 构造函数:返回一个内容为Value的String对象 参数: ①value {String} :字符串 返回值: {String对象} 返回一个内容为Value的String对象 示例: 复制代码 代码如下: var demoStr = new String('abc'); console.log(typeo

Javascript Global对象_基础知识

Global对象 Global对象是ECMAScript中最特别的对象,因为实际上它根本不存在.如果尝试编写下面的代码,将得到错误: 错误消息显示Global不是对象,但刚才不是说Global是对象吗?没错.这里需要理解的主要概念是,在ECMAScript中,不存在独立的函数,所有函数都必须是某个对象的方法.本书前面介绍的函数,如isNaN().isFinite().parseInt()和parseFloat()等,看起来都像独立的函数.实际上,它们都是Global对象的方法.而且Global对

无殇 javascript正则练习器_正则表达式

一个正则表达式就是由普通字符(例如字符 a 到 z)以及特殊字符(称为元字符)组成的文字模式.该模式描述在查找文字主体时待匹配的一个或多个字符串.正则表达式作为一个模板,将某个字符模式与所搜索的字符串进行匹配. 这里有一些可能会遇到的正则表达式示例: JScript VBScript 匹配 /^\[ \t]*$/ "^\[ \t]*$" 匹配一个空白行. /\d{2}-\d{5}/ "\d{2}-\d{5}" 验证一个ID 号码是否由一个2位数字,一个连字符以及一个

详细谈谈javascript的对象_基础知识

javascript中有很多对象内容,挑几个感觉用的比较多的讲解. 在网上学习一些和看javascript的学习手册. 如果要这个手册的可以留言,看到了我就发给你.恩,接下来总结一下我自己对象进阶之路. 1.对象:    (1)javascript中的所有事件都是对象:字符串.数组.函数.....   (2)每个对象带有属性和方法.   (3)JS允许自定义对象. 2.自定义对象 :  (1)定义并创建对象实例.  (2)使用函数来定义对象,然后创建新的对象实例. 例(针对2-(1)): 方法1

浅谈JavaScript Array对象_基础知识

Array 数组 1. 介绍       数组是值的有序集合.每个值叫做一个元素,而每个元素在数组中有一个位置,以数字表示,称为索引.JavaScript数组是无类型:数组元素可以是任意类型,并且同一个数组中的不同元素也可能有不同的类型. --<JavaScript权威指南(第六版)> 2. 定义 复制代码 代码如下: var names = new Array("张三", "李四", "王五"); //或者 var names =

JavaScript基本对象_基础知识

作者:excelence转贴 整理日期:2004年6月15日 本文不只是关于JavaScript的,它是关于Notes/Domino中的JavaScript的! 虽然如是说,不过还是值得一看! 希望你有所收获! 亲密接触单选按钮.复选框和JavaScript的一些有趣的事情  我将以对象模型和一些常用对象开始,因为JavaScript里的一切都是从对象展开的.记住,本文不只是关于JavaScript的,它是关于Notes/Domino中的JavaScript的. 窗口 窗口是对象模型的顶端对象.

Javascript Math对象_基础知识

Math对象 Math对象是在高中数学课就学过的内置对象.它知道解决最复杂的数学问题的所有公式,如果给它要处理的数字,即能计算出结果. Math对象有几个属性,主要是数学界的专用值.下表类出了这些属性: 属  性 说    明 E 值e,自然对数的底 LN10 10的自然对数 LN2 2的自然对数 LOG2E 以2为底E的对数 LOG10E 以10为底E的对数 PI 值π SQRT1_2 1/2的平方根 SQRT2 2的平方根 虽然这些值的意义与用法不在本书讨论范围内,但如果清楚它们是什么,在需