js正则

DNA图谱 / 问答 / 标签

JS正则表达式里 下划线不能再最后。怎么写

var a= new RegExp("[^w]+[_\-.]"); 正则var b="asdfsad_";//用于被匹配的字符串alert(a.test(b));如果下划线在最后 返回true 否则为false

js正则 验证 A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z

正则表达式如下:^[A-Z](,[A-Z])*$js示例如下:var a = /^[A-Z](,[A-Z])*$/g;alert(a.test("A,F,C,C,Z"));//truealert(a.test("B,C,"));//falsealert(a.test(",X,Z"));//false扩展资料JavaScript一种直译式脚本语言,是一种动态类型、弱类型、基于原型的语言,内置支持类型。它的解释器被称为JavaScript引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在HTML(标准通用标记语言下的一个应用)网页上使用,用来给HTML网页增加动态功能。在1995年时,由Netscape公司的Brendan Eich,在网景导航者浏览器上首次设计实现而成。因为Netscape与Sun合作,Netscape管理层希望它外观看起来像Java,因此取名为JavaScript。但实际上它的语法风格与Self及Scheme较为接近。参考资料:百度百科-JS

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之类的字符。 元字符代表有特殊含义非字母字符,如、w、d、+、*、? 等。 常用的元字符 更多的JS正则元字符请参考: http://www.runoob.com/regexp/regexp-metachar.html 一般情况下正则表达式中的一个字符对应字符串中的一个字符,如表达式ab的含义是ab。 表达式中用 [] 来定义一个字符类,表示可以匹配[]里面的这类字符,是一个泛指,而不是一一对应的关系。 如表达式[abc123],表示有其中一个字符串都可以匹配。 在字符类里面使用横线-连接2个数字或者字母就可以构建一个范围类,如[a-zA-z0-9-]表示可以匹配26个大小写字母和0-9的全部数字以及横线-。 注意,要匹配横线”-“,必须把横线放在最后面。 预定义类可以理解为JS默认给我们写好的范围类,让我们可以使用一个简单的元字符来使用它。如”w”就是一个预定义类,它等价于范围类[A-Za-z0-9_];“.”可以匹配除 “ ” 之外的任何单个字符。 边界包含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 是包含子表达式的正则表达式,那么返回的数组中包括与这些子表达式匹配的字串(但不包括与整个正则表达式匹配的文本) 正则表达式语法语意测试工具: https://regexper.com/