JavaScript正则(一)
1、字符组:
^ $ 说的是开始位置和结束位置,在JS中,既表示字符串的起始位置和结束位置,也表示行的起始位置和结束位置
console.log(/^\d$/.test('2')); // true 这里的 \d 代表的是数字
console.log(/^\d$/.test('a')); // false
[ ] 是一个字符集合,匹配他包含的任一个字符
console.log(/^[0123456]$/.test('0')); // true
console.log(/^[0123456]$/.test('7')); // false
console.log(/^[0123456]$/.test('12')); // false 在这里在[0123456]代表的是一个字符,所以来匹配 12 返回 false
{m,n} 代表重复的次数,这个也叫量词
console.log(/^\d{1,3}$/.test('123')); // true 在这是说可以出现 1 到 3 个数字
console.log(/^\d{1,3}$/.test('1')); // true
console.log(/^\d{1,3}$/.test('1234')); // false
? + * 这些也叫量词
var res = /^<[^>/]([a-zA-Z]+)[^>/]>$/
console.log(res.test('<div>')); // true 这里这个正则匹配的是一个 html open tag,但是还有点问题不能匹配 <u> 这样的标签
console.log(res.test('<div/>')); // false
这里的 [^>/] 代表的是这个地方不能出现 > 和 / ,就是非的意思
- 代表的是一个范围 [a-zA-Z] 限制了标签名只能是大小写字母的组合
[a-zA-Z]+ 这里的 + 代表的是最少出现一次,出现次数没有上限
?代表了 可能出现也可能不出现,但是最多只能出现一次
var res = /^travell?er$/;
console.log(res.test('traveller')); // true 这几个量词都是限制他们前一个字符
console.log(res.test('traveler')); // true
* 代表了 可能出现也可能不出现,出现次数没有上限
var res3 = /^\"[^\"]*\"$/
console.log(res3.test('\"some\"')); // true 这里在双引号前面的 \ 都是对 “ 的转义
console.log(res3.test('\"\"')); // true
环视:(?!……)和(?=……) (?<!……) 和(?<=……) 前面的那一对是否定顺序换和肯定顺序换,后面的一对是否定定循环和肯定逆循环
var res = /^<(?!\/)([^'">]+)(?<!\/)>$/
console.log(res.test('<div>')); // true
console.log(res.test('</div>')); // false
console.log(res.test('<div/>')); // false
<(?!\/) 的意思是在 < 的右侧不能出现 /,为了排除 close tag \/ 是对 / 进行转义
(?<!\/)> 的意思是在 > 的左侧不能出现 / 为了排除 close-selfing tag
var res = /^<(?!\/)([^'">]+)(?<=\/)>$/
console.log(res.test('<div>')); // false
console.log(res.test('<div/>')); // true
(?<=\/)> 这把 ! 变成了= ,意思是在 > 的左侧是 / ,匹配的是html的 close tag \s 代表的是空白符,可能是空格也可能是换行 \S 是\s 的补集 \d 代表的是数字,\D 是\d 的补集 \w 代表的是[-a-z0-9A-Z],\W 是\w 的补集
\s\S \d\D \w\W 他们可以代表所有的字符
| ,就是或的意思,(\s|\d)+ 代表了不是数字就是空白字符,最少要出现一次
JavaScript正则(一)的更多相关文章
- JavaScript正则实战
*:first-child { margin-top: 0 !important; } .markdown-body>*:last-child { margin-bottom: 0 !impor ...
- 我也谈javascript正则匹配
一.javascript 正则全局匹配 g 慎用test()方法 来个例子: var a = /^[a-z]+/gi; a.test('bb123'); //true a.lastIndex ; // ...
- JavaScript正则式入门
正则式 正则表达式,又称规则表达式.(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表通常被用来检索.替换那些符合某个模式(规 ...
- JavaScript 正则
元字符 预定义类 边界 ^在中括号中时,匹配非hello的 str = 'hello world' str.match(/[^hello]/g) //[" ", "w&q ...
- JavaScript正则中\1\2的作用
一.示例 1. 验证6个相同的数字 var reg = new RegExp(/^(\d)\1{5}/g); var a = '333333'; if(reg.test(a)) { alert('ri ...
- JavaScript 正则表达收集整理
JavaScript 正则表达收集整理 //可为空 /^\s*$/ //密码验证,必须且只含有数字和字母,可以拥有英文符号,6-17位 /(?=.{,})(?=.*\d)(?=.*[a-z])[\x2 ...
- JavaScript正则常用知识总结
一.JavaScript正则相关方法 str.match(regexp)与regexp.exec(str)功能类似. str.search(regexp)与regexp.test(str)功能类似. ...
- JavaScript 正则的使用方法
JavaScript正则方法 1.compile 编译一个正则表达式对象 rgExp.compile(pattern, [flags]) pattern字符串表达式 2.exec 在指定字符串中执行 ...
- Javascript正则构造函数与正则表达字面量&&常用正则表达式
本文不讨论正则表达式入门,即如何使用正则匹配.讨论的是两种创建正则表达式的优劣和一些细节,最后给出一些常用正则匹配表达式. Javascript中的正则表达式也是对象,我们可以使用两种方法创建正则表达 ...
- JavaScript正则验证邮箱
正则表达式/^正则$/.test() <html> <head> <title>JavaScript</title> <meta charset= ...
随机推荐
- Silverlight FullScreen 全屏
<UserControl x:Class="FullScreen.MainPage" xmlns="http://schemas.microsoft.com/win ...
- JAVA HTTP请求和HTTPS请求
HTTP与HTTPS区别:http://blog.csdn.net/lyhjava/article/details/51860215 URL发送 HTTP.HTTPS:http://blog.csdn ...
- svn使用&&常用操作&&问题处理
第一部分: SVN使用 svn介绍 即subversion的简称. 版本控制系统(CVS)包括集中式版本控制系统(CVCS)和分布式版本控制系统(DCVS).svn是集中式版本控制系统. 可以用于团队 ...
- eclipse中使用自带的git提交项目
1.自带git插件进行配置我们的用户名和密码,即是自己github注册用户.windows--perferences--Team--Git--Configuration 2.eclipse生成SSH2 ...
- C#设计模式——单例
单例模式是设计模式中最简单的形式之一.这一模式的目的是使得类的一个对象成为系统中的唯一实例.对于系统中的某些类来说,只有一个实例很重要,例如,一个系统中可以存在多个打印任务,但是只能有一个正在工作的任 ...
- MVC在页面View上获取当前控制器名称、Action名称以及路由参数
有时候在封装MVC通用控件时需要在页面上获取这些数据. 用以下方法即可: //获取控制器名称: ViewContext.RouteData.Values["controller"] ...
- Oracle入门基础(1)
1.数据库系统和数据管理系统的区别? 数据库系统=数据库的管理系统+oper操作员+硬件 2.Oracle的版本 8i /9i 10g/11g 12c(cloud) 3.Oracle主要组 ...
- js获取文件上传进度
js获取文件上传进度: <input name="file" id="FileUpload" type="file" /> &l ...
- web worker技术-js新线程
web worker的小例子,用来入门很合适,建议启动服务来开发.可以使用node的anywhere. <!DOCTYPE html> <html lang="en&quo ...
- Android OS Startup
OS puts emphases on how to provide interfaces to user's APPs for using hardware device in the conven ...