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正则(一)的更多相关文章

  1. JavaScript正则实战

    *:first-child { margin-top: 0 !important; } .markdown-body>*:last-child { margin-bottom: 0 !impor ...

  2. 我也谈javascript正则匹配

    一.javascript 正则全局匹配 g 慎用test()方法 来个例子: var a = /^[a-z]+/gi; a.test('bb123'); //true a.lastIndex ; // ...

  3. JavaScript正则式入门

    正则式 正则表达式,又称规则表达式.(英语:Regular Expression,在代码中常简写为regex.regexp或RE),计算机科学的一个概念.正则表通常被用来检索.替换那些符合某个模式(规 ...

  4. JavaScript 正则

    元字符 预定义类 边界 ^在中括号中时,匹配非hello的 str = 'hello world' str.match(/[^hello]/g) //[" ", "w&q ...

  5. JavaScript正则中\1\2的作用

    一.示例 1. 验证6个相同的数字 var reg = new RegExp(/^(\d)\1{5}/g); var a = '333333'; if(reg.test(a)) { alert('ri ...

  6. JavaScript 正则表达收集整理

    JavaScript 正则表达收集整理 //可为空 /^\s*$/ //密码验证,必须且只含有数字和字母,可以拥有英文符号,6-17位 /(?=.{,})(?=.*\d)(?=.*[a-z])[\x2 ...

  7. JavaScript正则常用知识总结

    一.JavaScript正则相关方法 str.match(regexp)与regexp.exec(str)功能类似. str.search(regexp)与regexp.test(str)功能类似. ...

  8. JavaScript 正则的使用方法

    JavaScript正则方法 1.compile 编译一个正则表达式对象 rgExp.compile(pattern, [flags])  pattern字符串表达式 2.exec 在指定字符串中执行 ...

  9. Javascript正则构造函数与正则表达字面量&&常用正则表达式

    本文不讨论正则表达式入门,即如何使用正则匹配.讨论的是两种创建正则表达式的优劣和一些细节,最后给出一些常用正则匹配表达式. Javascript中的正则表达式也是对象,我们可以使用两种方法创建正则表达 ...

  10. JavaScript正则验证邮箱

    正则表达式/^正则$/.test() <html> <head> <title>JavaScript</title> <meta charset= ...

随机推荐

  1. Java基础04-数据的输入

    1.为什么要有数据的输入? 实现人机进行交互 2.什么是数据的输入? 利用扫描仪Scanner进行数据输入 3.怎么使用扫描仪Scanner? (1)放在类声明之前,引入扫描仪 import java ...

  2. vue中遇到的坑

    如何解决在vue中替换图片.一个使用base64,而我们使用zepto之后,src找不到资源,因为已经打包了,难道强行写base64. 1. 引入文件时语法很重要! import "Foot ...

  3. pta08-图7 公路村村通 (30分)

    08-图7 公路村村通   (30分) 现有村落间道路的统计数据表中,列出了有可能建设成标准公路的若干条道路的成本,求使每个村落都有公路连通所需要的最低成本. 输入格式: 输入数据包括城镇数目正整数N ...

  4. Docker学习笔记(2)-docker镜像操作

    本节将会涉及Docker的镜像操作. 1. 获取镜像 如何获取Docker Hub上的镜像?可通过docker pull命令获取,其格式为: docker pull [选项] [Docker Regi ...

  5. POJ 3177——Redundant Paths——————【加边形成边双连通图】

    Redundant Paths Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Sub ...

  6. 【防火墙】DMZ

    DMZ是英文“demilitarized zone”的缩写,中文名称为“隔离区”,也称“非军事化区”.它是为了解决安装防火墙后外部网络的访问用户不能访问内部网络服务器的问题,而设立的一个非安全系统与安 ...

  7. C# .NET中自带的委托Actoin、Func详解

    委托是.NET中强大的功能,而.NET为我们提供了2个非常实用的泛型委托,分别是Action.Func [Action] Action是.NET内部提供的一个无返回值.泛型的委托,有16重载,分别是0 ...

  8. maven课程 项目管理利器-maven 3-6 maven中Pom.xml的解析 3星

    本节主要讲了pom中常用的标签 1 常用的标签 2 非常用的标签 1 常用的标签 a 坐标 groupid 反写公司网址+项目名 artifactId 项目名+模块名 version 版本号:3位版本 ...

  9. python面试题——网络编程和并发

    1.简述 OSI 七层协议. 物理层(电信号.比特流) 基于电器特性发送高低电压(电信号) RJ45.IEEE802.3 数据链路层(数据帧) 定义了电信号的分组方式,分组方式后来形成了统一的标准,即 ...

  10. SublimeText插件 : sass语法高亮

    安装 :sublime中安装sass插件和sass build插件  就可以高亮显示sass 步骤:安装 sass插件和sass build (安装过程不细说) 步骤2:打开.sass文件,进行以下设 ...