js正则表达式,JS正则表达式

http://www.itjxue.com  2023-01-16 01:53  来源:未知  点击次数: 

JS正则表达式基础认知

? ? ? ? 正则表达式,又叫规则表达式,英文名Regular Expression,本质是操作字符串

? ? ? ? ?1、模式匹配? ? 表单验证

? ? ? ? ?2、文本检索? ? 搜索

? ? ? ? ?3、替换? ? ? ? 过滤

? ? ? ? ?简单,方便,性能高

? ? ? ? var reg=new RegExp('规则','模式')? 通过构造函数创造

? ? ? ? var reg=/规则/模式? ? ? ? ? ? ? ? 通过字面量创建

? ? ? ?i? 忽略大小写

? ? ? ?g? 全局

? ? ? ?m? 多行

? ? ? ?注:不分前后顺序

? ? ? str.match(正则)? 返回数组 没有返回 null

? ? ? str.search(正则)? 返回下标? 没有返回-1

? ? ? str.replace(正则,替换成谁)? 返回替换后的字符串

? ? ? str.replace(正则,function(s){

? ? ? ? ? ? ? ? ? ? ? ?s 符合正则条件的字符串

? ? ? ?})

? ? ? ?\d? 数字 /[0-9]/

? ? ? ?\s? 空格

? ? ? ?\w? /[0-9a-zA-Z_]/ 单词

? ? ? ?\D? 非数字? /[^0-9]/

? ? ? ?\S? 非空白

? ? ? ?\W? 非单词? /[^0-9a-zA-Z_]/

.(点)??? 代表任意

? ? ? ? ?\.? 代表.

? ? ? ? ?\\? 代表\

? ? ? ? ?\\\\? 代表\\

? ? ? ? ? \/? ? 代表/

? ? ? ? ? 只要有特殊意义的都要转译

? ? ? ? ? +? {1,m}? 若干个? 最少1个最多不限

? ? ? ? ? ? {0,1}? 可有可无

? ? ? ? ? *? {0,m}? 可以没有,多了不限

? ? ? ? ? {n}? 正好n个

? ? ? ? ?{n,m}? 最少n个 最多m个

? ? ? ? ?{n,}? 最少n个,最多不限

? ? ? ? ?{,m} × 没有这种写法

? ? ? ? ^? 行首

? ? ? ? ?注:如果^单独使用,代表字符串行首,配合m使用会识别段落

? ? ? ? $? 行尾

? ? ? ? [] 中括号

? ? ? ? ? ? ?1、[]里面的东西都是或的形式

? ? ? ? ? ? ?2、[]里面和放范围

? ? ? ? ? ? ?3、[^]? 不代表行首,代表除去里面的范围

? ? ? ? ? ? ?4、其他特殊符号代表本身

? ? ? ? ?1、test()? 一般配合^

? ? ? ? ? ? ? ?功能:用于检测是否于正则匹配。

? ? ? ? ? ? ? ?返回:布尔值,true匹配,false不匹配

? ? ? ? ? ? ? ?语法:reg.test(检测的内容)

? ? ? ? ? 2 exec()

? ? ? ? ? ? ? ?功能:用于检测是否于正则匹配。

? ? ? ? ? ? ? ?返回:数组, 不匹配返回null

? ? ? ? ? ? ? ?语法:reg.test(检测的内容)

? ? ? ? ? ? ? ?再做验证之前:验证分两种,一种强校验,一种弱校验

? ? ? ? ? ? (1)验证手机号? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /1[23457]\d{9}/

? ? ? ? ? ? (2)验证座机号? ? ? 区号-座机号? ? ? ? ? ? /(0[1-9]\d-)?[1-9]\d{7}/

? ? ? ? ? ? (3)验证qq? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /[1-9]\d{4,11}/

? ? ? ? ? ? (4)实现一个trim函数 去掉收尾空格? ? ? /^\s+|\s+$/g

? ? ? ? ? ? (5)中文? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /[\u4e00-\u9fa5]/

? ? ? ? ? ? (6)验证年龄? ? ? ?18-100? ? ? ? ? ? ? ? ? ? ? ?/^1[89]|[2-9]\d|100$/

? ? ? ? ? ? (7)邮箱:? ? ?asdsad@163.com? ? ? ? ? ?/^\w{5,12}@[a-z0-9]{2,8}\.com$/

? ? ? ? ? ? (8)? 过滤html? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? /[^]+/g;

? ? ? ? 1、分组? ? ab+ abbbb? (ab)+

? ? ? ? 2、匹配子级

? ? ? ? ? ? ? 配合replace使用? str.replace(reg,function(s,a,b){

? ? ? ? ? ? ? ?s是 整体

? ? ? ? ? ? ? ?a是第一个括号的项

? ? ? ? ? ? ? ?b是第二个括号的项

? ? ? ? ? })

? ? ? ? 3、优选级? ^(1[89]|[2-9]\d|100)$

? ? ? ? 4、重复的子项

? ? ? ? ? ? ? abbb? ? ? ? ? /(a)(b)\2+/

今天先给大家总结到这儿,后续还会有补充

JS正则表达式详解

RegExp是JS的正则表达式对象,实例化一个RegExp对象有 字面量 和 构造函数 2种方式。

字面量实例化RegExp对象

var reg=/js/gi;

开始和结束的斜线/是正则表达式的边界,//中间的文本是正则表达式文本,后面的gi是正则表达式的修饰符。

构造函数实例化RegExp对象

var reg=new Regex(‘js’,’gi’);

第一个参数是正则表达式文本,第二个参数是正则表达式修饰符。

global:RegExp 对象是否具有标志 g。

ignoreCase:RegExp 对象是否具有标志 i。

lastIndex:一个整数,标示开始下一次匹配的字符位置。

multiline:RegExp 对象是否具有标志 m。

source:正则表达式的源文本。

RegExp 对象有 3 个方法:test()、exec() 以及 compile()。

test()

test() 方法检索字符串中的指定值。返回值是 true 或 false。

示例:

var reg=/js/gi;

var result=reg.test(‘I like js’);

结果:true

exec()

exec() 方法检索字符串中的指定值。返回值是被找到的值。如果没有发现匹配,则返回 null。

示例:

var reg=/js/gi;

var result=reg.exec(‘I like JS’);

结果:JS

compile()

compile() 方法用于改变 RegExp。

compile() 既可以改变检索模式,也可以添加或删除第二个参数。

g:global全文搜索,如果不添加此参数,搜索到第一个匹配就会停止

i:ignore case 不区分大小写,默认是区分大小写的

m:multiple lines 多行搜索,默认只搜索第一行

正则表达式文本部分包含 原义文本字符 和 元字符, 其中的原义文本字符代表字符本身意义的字符,如abc123之类的字符。

元字符代表有特殊含义非字母字符,如\b、\w、\d、+、*、? 等。

常用的元字符

更多的JS正则元字符请参考:

一般情况下正则表达式中的一个字符对应字符串中的一个字符,如表达式ab的含义是ab。

表达式中用 [] 来定义一个字符类,表示可以匹配[]里面的这类字符,是一个泛指,而不是一一对应的关系。

如表达式[abc123],表示有其中一个字符串都可以匹配。

在字符类里面使用横线-连接2个数字或者字母就可以构建一个范围类,如[a-zA-z0-9-]表示可以匹配26个大小写字母和0-9的全部数字以及横线-。

注意,要匹配横线”-“,必须把横线放在最后面。

预定义类可以理解为JS默认给我们写好的范围类,让我们可以使用一个简单的元字符来使用它。如”\w”就是一个预定义类,它等价于范围类[A-Za-z0-9_];“.”可以匹配除 “\n” 之外的任何单个字符。

边界包含2种,一种是以字符串开始或结尾的边界,另一种是单词边界

量词表示可以匹配连续多次的元字符

JS正则表达式默认是贪婪模式匹配,它会以最多匹配原则进行查找,非贪婪模式可以让表达式以最少匹配原则进行查找。

非贪婪模式只需要在量词后面加上”?”即可,如”123456789″字符串想以3个数字为一组进行匹配表达式写法/\d{3,5}?/g。

表达式中用 () 来定义一个分组,使元字符可以作用于一个表达式字符串组合,如/(js|php){3}/gi。

表达式中的每一个分组匹配的内容都是一个可以捕获的变量,可以使用$1、$2、$3… 来取值,如表达式/(\d{4})-(\d{2})-(\d{2})/中包含$1、$2、$3。如果想忽略分组匹配的内容,需要在分组前面增加“?:”,就可以得到分组匹配之外的内容。

前瞻就是正则表达式后面加上断言部分,它不但要匹配表达式部分,还需要满足断言部分,匹配的结果不会包含断言部分。

正向前瞻 exp(?=assert) 如 “\w(?=\d)”

负向前瞻 exp(?!assert) 如 “\w(?!\d)”

match()

stringObject.match(regexp)

match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。

如果没有找到任何匹配的文本, match() 将返回 null。

否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。该数组的第 0 个元素存放的是匹配文本,而其余的元素存放的是与正则表达式的子表达式匹配的文本。

search()

stringObject.search(regexp)

search() 方法不执行全局匹配,它将忽略标志 g。它同时忽略 regexp 的 lastIndex 属性,并且总是从字符串的开始进行检索,这意味着它总是返回 stringObject 的第一个匹配的位置。

replace()

stringObject.replace(regexp/substr,replacement)

字符串 stringObject 的 replace() 方法执行的是查找并替换的操作。它将在 stringObject 中查找与 regexp 相匹配的子字符串,然后用 replacement 来替换这些子串。如果 regexp 具有全局标志 g,那么 replace() 方法将替换所有匹配的子串。否则,它只替换第一个匹配子串。

replacement 可以是字符串,也可以是函数。如果它是字符串,那么每个匹配都将由字符串替换。但是 replacement 中的 $ 字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。

split()

stringObject.split(separator,howmany)

如果 separator 是包含子表达式的正则表达式,那么返回的数组中包括与这些子表达式匹配的字串(但不包括与整个正则表达式匹配的文本)

正则表达式语法语意测试工具:

Js 中的 正则表达式?

1定义正则表达式

在js中定义正则表达式很简单,有两种方式,一种是通过构造函数,一种是通过//,也就是两个斜杠。

例如

代码如下:

var re =new RegExp("\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");

使用构造函数定义正则表达式,注意大小写,负责就会不起作用。由于构造函数的参数是一个字符串,也可以是两个斜杠的方式定义,遇到一些特殊字符就需要使用\进行转义

通过双斜杠的方式定义同样的正则表达式

代码如下:

var re =/\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;

代码如下:

var re =new RegExp( /^\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/);

可以和构造函数达到同样的效果,但仔细分析,发现,通过构造函数需要更多的转义字符\

2关于验证的三个正则表达式方法

使用正则表达式的主要有字符串的方法match,正则表达式的方法exec,test

正则表达式方法test测试给定的字符串是否满足正则表达式,返回值是bool类型的,只有真和假,如果只是单纯的判断,不需要其他的处理,可以使用尤其是验证时。

代码如下:

function test(){

var text="index.aspx?test=1ww=2www=3"; //

var re =/\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;

// var re =new RegExp("\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");

var result= re.test(text);

if(result)

{

alert("ok");

}else

{

alert("err");

}

}

正则表达式方法exec测试给定的字符串是否满足正则表达式,返回匹配到的字符串,如果没有匹配的则返回null,和test基本一致,如果需要获取匹配的各个子字符串,可以使用下标的方式,把上边的test的例子可以改写如下

代码如下:

function test(){

var text="index.aspx?test=1ww=2www=3";

var re = /\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;

// var re =new RegExp( "\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");

var result= re.exec(text);

if(result)

{

alert("ok");

alert(result); // 是?test=1ww=2www=3,ww=2

alert(result[0]+",0");//是?test=1ww=2www=3

alert(result[1]+",1");//是ww=2

}else

{

alert("err");

}

}

match其实是字符串的方法,但参数确是一个正则表达式,把上边的例子改写后,如下

代码如下:

function test(){

var text="index.aspx?test=1ww=234"; //

var re = /\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;

// var re2 = "(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}"

var result= text.match(re);

if(result)

{

alert(result);//?test=1ww=234,test=1

alert(result[0]+",0");//?test=1ww=234

alert(result[1]+",1");//test=1

}else

{

alert("err");

}

}

其实字符串类还有多个函数可以传递正则表达式,split,search,replace等但这些方法已经不适合验证了。

代码如下:

function test(){

var text="index.aspx?test=1ww=234"; //

var re = /\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;

// var re2 = "(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}"

var result= text.split(re);

alert(result);

alert(result[0]+",0");

alert(result[1]+",1");

}

3正则表达式式的转义字符

在正则表达式中会经常出现转义字符,例如问号?在正则表达式中有特殊的含义,如果需要匹配问号?就需要转义,使用转义字符反斜杠\

如下两个都是匹配问号开头的一段字符串

代码如下:

function test(){

var text="?test=1ww=2www=3";

var re = /^\?(\w{1,}=\w{1,}){1,}\w{1,}=\w{1,}/;// \?表示配置问号?

// var re =new RegExp( "^\\?(\\w{1,}=\\w{1,}){1,}\\w{1,}=\\w{1,}");// \\?表示配置问号?

var result= re.exec(text);

if(result)

{

alert("ok");

alert(result);

alert(result[0]+",0");

alert(result[1]+",1");

}else

{

alert("err");

}

}

js正则表达式是什么?

查找cookie中的等式,name是变量,如果name值是字符串history,则查找history=xxxxx;

(new RegExp("(^| )"+name+"=([^;]*)(;|$)"(^| ) 匹配行的开头或空格,"=([^;]*)(;|$)" 等号字符后面跟非分号的字符串,最后是分号或字符串的结尾 ,+号是将三个字符串连接起来,整个匹配一个等式,=号前是name变量中字符串,=后是值,等号后匹配到直到遇到分号或行尾。

扩展资料:

正则表达式是对字符串(包括普通字符(例如,a 到 z 之间的字母)和特殊字符(称为“元字符”))操作的一种逻辑公式,就是用事先定义好的一些特定字符、及这些特定字符的组合,组成一个“规则字符串”,这个“规则字符串”用来表达对字符串的一种过滤逻辑。正则表达式是一种文本模式,该模式描述在搜索文本时要匹配的一个或多个字符串。

参考资料来源:百度百科-正则表达式

(责任编辑:IT教学网)

更多

相关管理维护文章

推荐管理维护文章