js下 Day15、正则表达式
一.正则表达式简介
什么是正则表达式
正则表达式,也叫规则表达式, 是对字符串操作的一种逻辑公式。
为什么要使用正则?
1、使用极简单的方式,去匹配字符串
2、速度快,代码少
3、在复杂的字符串中快速精准的匹配想要的字符
正则表达式创建:
字面量: var reg = / 规则/修饰符;
实例化: var reg = new RegExp( 规则 ,修饰符 );
基本语法
1.修饰符
| i | 忽略大小写 |
|---|---|
| g | 全局匹配 |
| m | 多行匹配 |
2.元字符
| \d | 匹配数字 |
|---|---|
| \D | 匹配非数字 |
| \w | 匹配数字字母下划线 |
| \W | 匹配非数字字母下划线 |
| \s | 匹配空字符 |
| \S | 匹配非空字符 |
| \b | 匹配单词边界 |
| \B | 匹配非单词边界 |
| [\u4e00-\u9fa5] 有事100,有酒发我 | 匹配中文 |
3.特殊字符
| ** | 转义字符,将在正则中有特殊含义的字符转为普通字符 |
|---|---|
| [] | 中括号中的字符匹配任意一个 |
| ^ | 以什么开始 |
| $ | 以什么结束 |
| [^] | 取反,除了中括号里以外的字符 |
| . | 除了换行以外的任意字符 |
| | | 或 |
| () | 分组 |
4.限定符
| {n,m} | 匹配n-m个 |
|---|---|
| {n} | 匹配n个 |
| {n,} | 最少匹配n个 |
| + | 一个或多个,相当于{1,} |
| ** *** | 0个或多个,相当于{0,} |
| ? | 0个或一个,相当于{0,1} |
#二.常见正则
**1. ** 手机号正则
以数字1开头
第二位不能是[012]
后9位任意数字
**2. ** 邮箱正则
开头可以多个是数字字母下划线
中间有@符
@符后也是多个数字字母下划线
接着匹配 .
后面跟常见尾缀**(com | cn | net)**
**3.QQ ** 正则
不能以0开头
长度为5-11位
**4. ** 网址正则
http开头,s可有可无,后面是://
@前是数字字母下划线
@后.前是数字字母下划线
.后是尾缀
**5. ** 匹配前后空格
只匹配开头或结尾,不管中间
#三.课堂小案例
1.敏感词替换( **replace(reg, ** ’’) )

2.找数字加2( replace(reg,function($0){}) )

3.转小驼峰( replace(reg,function($0,$1){}) )

4.字符串 match() 方法
语法: 字符串.match(正则)
返回值: 数组
**match()**方法返回匹配项组成的数组(支持全局匹配)
5.正则exec()方法
语法: 正则.exec(字符串)
返回值: 数组
**exec()**方法返回匹配项组成的数组(不支持全局匹配)
不加g永远只能找到第一个
加g该方法调用一次匹配第一个,再调用一次匹配第二个,以此类推,找不到返回null

6.字符串的split()方法
split方法支持使用正则当做分隔符
#四.课堂小结
1.修饰符: **i ** 忽略大小写 g全局匹配
2.元字符: **\d ** 数字 \w数字字母下划线 \s空字符 \b单词边界
3.特殊字符: **\ ** 转义 |或 []任意一个 [^]除了 ^开头 $结尾 .任意 ()分组
4.限定符: **+ 1 ** 或多 * 0或多 ? 0或1 {}
5.正则方法: test() 返回布尔值 exec() 返回数组,不支持全局匹配
6.字符串方法: replace() 替换 macth()返回数组,支持全局匹配
#五.作业 -- 表单验证
效果图:

功能思路分析:
1. 用户名验证
\1. 给用户名文本框绑定失去焦点事件(blur)
\2. 编写手机号正则和邮箱正则
\3. 验证文本框的内容是否符合手机号正则或邮箱正则
\4. 验证通过返回true,并且隐藏错误提示
5. 验证失败返回false,并且显示错误提示
2. 密码验证
\1. 给密码文本框绑定失去焦点事件(blur)
\2. 编写非纯数字和非纯字母正则
\3. 验证文本框的内容是否符合非纯数字并且和纯字母正则,并且长度3-6
\4. 验证通过返回true,并且隐藏错误提示
5. 验证失败返回false,并且显示错误提示
3. 验证码验证
\1. 给验证码文本框绑定失去焦点事件(blur)
\2. 判断文本框里的内容是否与验证码盒子中的内容一致
\3. 验证通过返回true,并且隐藏错误提示
\4. 验证失败返回false,并且显示错误提示
4. 切换验证码
\1. 封装一个获取随机验证码的方法
\2. 给换一换按钮绑定点击事件(click),调用随机验证码方法
5. 登录验证
\1. 给登录按钮绑定点击事件
\2. 调用用户名、密码和验证码的失去焦点事件,当他们返回值都为真是,跳转页面(location.href),并将用户信息传递过去
js下 Day15、正则表达式的更多相关文章
- Java/Js下使用正则表达式匹配嵌套Html标签
转自:http://www.jb51.net/article/24422.htm 以前写过一篇文章讲解如何使用正则表达式完美解决Html嵌套标签的匹配问题(使用正则表达式匹配嵌套Html标签),但是里 ...
- ASP.NET开发中主要的字符验证方法-JS验证、正则表达式、验证控件、后台验证
ASP.NET开发中主要的字符验证方法-JS验证.正则表达式.验证控件.后台验证 2012年03月19日 星期一 下午 8:53 在ASP.NET开发中主要的验证方法收藏 <1>使用JS验 ...
- 原生JS下拉加载插件分享。
无聊写了一个JS下拉加载插件,有需要的可以下载. // 使用 // new ManDownLoad("#ul","json/load.json",functio ...
- js下拉框
Js下拉框 http://sc.chinaz.com/tag_jiaoben/XiaLaKuang.html
- CSS+JS下拉菜单和纯CSS下拉菜单
下拉菜单 (思路:先把二级定位到屏幕外,鼠标悬停重新定位回来:另一个就是ul浮动,li也浮动) 下拉菜单的一般思路就是把子导航嵌套在无序列表中,把列表定位到屏幕之外,当鼠标悬停在其父列表项上时,重新定 ...
- 小议 js 下字符串比较大小
原文:小议 js 下字符串比较大小 之前群里有人问如何比较两个时间大小,他的时间格式是 2014-08-08 而不是 2014-8-8.所以我给的方法是 直接比较,如: var a = "2 ...
- node.js 下依赖Express 实现post 4种方式提交参数
上面这个图好有意思啊,哈哈, v8威武啊.... 在2014年的最后一天和大家分享关于node.js 如何提交4种格式的post数据. 上上一篇说到了关于http协议里定义的4种常见数据的post方法 ...
- js如何使用正则表达式实现过滤HTML标签?(/<[^<>]+>/g)
js如何使用正则表达式实现过滤HTML标签?(/<[^<>]+>/g) 一.总结 js进阶正则表达式实现过滤HTML标签(<>标签中不能包含标签实现过滤HTML标签 ...
- npm 是node.js下带的一个包管理工具
npm 是node.js下带的一个包管理工具 npm install -g webpack webpack是一个打包工具 gulp是一个基于流的构建工具,相对其他构件工具来说,更简洁 ...
随机推荐
- 被 C# 的 ThreadStatic 标记的静态变量,都存放在哪里了?
一:背景 1. 讲故事 前几天公号里有一位朋友留言说,你windbg玩的溜,能帮我分析下被 ThreadStatic 修饰的变量到底存放在哪里吗?能不能帮我挖出来,其实这个问题问的挺深的,玩高级语言的 ...
- 异或加密 - cr2-many-time-secrets(攻防世界) - 异性相吸(buuctf)
Crib dragging attack 在开始了解 Crib dragging attack 之前,先来理一理 异或. 异或加密 [详情请戳这里] XOR 加密简介 异或加密特性: ① 两个值相同时 ...
- 面试官:小伙子,你给我说一下Java中什么情况会导致内存泄漏呢?
概念 内存泄露:指程序中动态分配内存给一些临时对象,但对象不会被GC回收,它始终占用内存,被分配的对象可达但已无用.即无用对象持续占有内存或无用对象的内存得不到及时释放,从而造成的内存空间浪费. 可达 ...
- 装了IDM后看网页有时会自动弹出下载怎么办
我们在安装了IDM之后,浏览一些网站时可能会自动弹文件下载窗口,但有时内容并非我们要下载的.对此类自动弹下载对话框的情况,操作者可进行自定义设置.不仅可通过设置文件格式来禁止自动弹窗,也可通过设置特定 ...
- 两款超好用的Mac读写ntfs软件推荐给大家
活中我们免不了会使用一些硬盘设备来存储文件或者是数据,然而绝大多数的移动硬盘都是ntfs格式.Mac读写ntfs软件有很多,究竟哪一款适合我们? 首先,我们一起了解一下什么是ntfs格式.ntfs,是 ...
- 【PYTEST】第四章Fixture
知识点: 利用fixture共享数据 conftest.py共享fixture 使用多个fixture fixture作用范围 usefixture 重命名 1. 利用fixture共享数据 test ...
- 推荐系统实践 0x06 基于邻域的算法(1)
基于邻域的算法(1) 基于邻域的算法主要分为两类,一类是基于用户的协同过滤算法,另一类是基于物品的协同过滤算法.我们首先介绍基于用户的协同过滤算法. 基于用户的协同过滤算法(UserCF) 基于用户的 ...
- Contest 985
A 均移到黑色或白色即可. 时间复杂度 \(O\left(n\log n\right)\). B 枚举每种开关判断是否有灯只能靠该种开关控制. 时间复杂度 \(O\left(nm\right)\). ...
- Java集合【3】-- iterable接口超级详细解析
目录 iterable接口 1. 内部定义的方法 1.1 iterator()方法 1.2 forEach()方法 1.3 spliterator()方法 总结 iterable接口 整个接口框架关系 ...
- python—数据类型和变量
在python中,能够直接处理的数据类型和变量有整数.浮点数.字符串.布尔值.空值.变量. 一.整数 1.python可处理任意大小的整数,包括负整数,在程序中的表示方法与在数学中的方法一样.例如:0 ...