目标:

了解正则表达式
清楚正则表达式在 JavaScript 中的使用
明白正则表达式中的特殊字符
懂得正则表达式中的替换、提取

1. 正则表达式概述

1.1 什么是正则表达式

正则表达式( Regular Expression )是用于匹配字符串中字符组合的模式。在JavaScript中,正则表达式也是对象。

正则表通常被用来检索、替换那些符合某个模式(规则)的文本,例如验证表单:用户名表单只能输入英文字母、数字或者下划线,昵称输入框中可以输入中文(匹配)。此外,正则表达式还常用于过滤掉页面内容中的一些敏感词(替换),或从字符串中获取我们想要的特定部分(提取)等 。

其他语言也会使用正则表达式,本文主要是利用JavaScript 正则表达式完成表单验证。

1.2 正则表达式的特点

  1. 灵活性、逻辑性和功能性非常的强。
  2. 可以迅速地用极简单的方式达到字符串的复杂控制。
  3. 对于刚接触的人来说,比较晦涩难懂。比如:^\w+([-+.]\w+)@\w+([-.]\w+).\w+([-.]\w+)*$。
  4. 实际开发,一般都是直接复制写好的正则表达式. 但是要求会使用正则表达式并且根据实际情况修改正则表达式。

2. 正则表达式在js中的使用

2.1 正则表达式的创建

在 JavaScript 中,可以通过两种方式创建一个正则表达式。

方式一:通过调用RegExp对象的构造函数创建

var regexp = new RegExp(/123/);
console.log(regexp);

方式二:利用字面量创建 正则表达式

 var rg = /123/;

2.2 测试正则表达式

test() 正则对象方法,用于检测字符串是否符合该规则,该对象会返回 true 或 false,其参数是测试字符串。

var rg = /123/;
console.log(rg.test(123));//匹配字符中是否出现123  出现结果为true
console.log(rg.test('abc'));//匹配字符中是否出现123 未出现结果为false

3. 正则表达式中的特殊字符

3.1 正则表达式的组成

一个正则表达式可以由简单的字符构成,比如 /abc/,也可以是简单和特殊字符的组合,比如 /ab*c/ 。其中特殊字符也被称为元字符,在正则表达式中是具有特殊意义的专用符号,如 ^ 、$ 、+ 等。

特殊字符非常多,可以参考:

MDN

jQuery 手册:正则表达式部分

正则测试工具

3.2 边界符

正则表达式中的边界符(位置符)用来提示字符所处的位置,主要有两个字符

边界符 说明
^ 表示匹配行首的文本(以谁开始)
$ 表示匹配行尾的文本(以谁结束)

如果 ^和 $ 在一起,表示必须是精确匹配。

var rg = /abc/; // 正则表达式里面不需要加引号 不管是数字型还是字符串型
// /abc/ 只要包含有abc这个字符串返回的都是true
console.log(rg.test('abc'));   //true
console.log(rg.test('abcd'));  //true
console.log(rg.test('aabcd')); //true
console.log('---------------------------');
var reg = /^abc/; //必须以abc开头
console.log(reg.test('abc')); // true
console.log(reg.test('abcd')); // true
console.log(reg.test('aabcd')); // false
console.log('---------------------------');
var reg1 = /^abc$/; // 精确匹配 要求必须是 abc字符串才符合规范
console.log(reg1.test('abc')); // true
console.log(reg1.test('abcd')); // false
console.log(reg1.test('aabcd')); // false
console.log(reg1.test('abcabc')); // false

3.3 字符类

字符类表示有一系列字符可供选择,只要匹配其中一个就可以了。所有可供选择的字符都放在方括号内。

3.3.1 [] 方括号

表示有一系列字符可供选择,只要匹配其中一个就可以了

var rg = /[abc]/; // 只要包含有a 或者 包含有b 或者包含有c 都返回为true
console.log(rg.test('andy'));//true
console.log(rg.test('baby'));//true
console.log(rg.test('color'));//true
console.log(rg.test('red'));//false
var rg1 = /^[abc]$/; // 三选一 只有是a 或者是 b  或者是c 这三个字母才返回 true
console.log(rg1.test('aa'));//false
console.log(rg1.test('a'));//true
console.log(rg1.test('b'));//true
console.log(rg1.test('c'));//true
console.log(rg1.test('abc'));//false
----------------------------------------------------------------------------------
var reg = /^[a-z]$/ //26个英文字母任何一个字母返回 true  - 表示的是a 到z 的范围
console.log(reg.test('a'));//true
console.log(reg.test('z'));//true
console.log(reg.test('A'));//false
-----------------------------------------------------------------------------------
//字符组合
var reg1 = /^[a-zA-Z0-9]$/; // 26个英文字母(大写和小写都可以)任何一个字母返回 true
------------------------------------------------------------------------------------
//取反 方括号内部加上 ^ 表示取反,只要包含方括号内的字符,都返回 false 。
var reg2 = /^[^a-zA-Z0-9]$/;
console.log(reg2.test('a'));//false
console.log(reg2.test('B'));//false
console.log(reg2.test(8));//false
console.log(reg2.test('!'));//true

3.3.2 量词符

量词符用来设定某个模式出现的次数。

量词 说明
* 重复0次或更多次
+ 重复1次或更多次
? 重复0次或1次
{n} 重复n次
{n,} 重复n次或更多次
{n,m} 重复n到m次

3.3.3 括号总结

1.大括号 量词符. 里面表示重复次数

2.中括号 字符集合。匹配方括号中的任意字符.

3.小括号表示优先级

正则表达式在线测试

3.4 预定义类

预定义类指的是某些常见模式的简写方式.

案例:验证座机号码

var reg = /^\d{3}-\d{8}|\d{4}-\d{7}$/;
var reg = /^\d{3,4}-\d{7,8}$/;

3.5 正则替换、提取

3.5.1 replace 替换

replace() 方法可以实现替换字符串操作,用来替换的参数可以是一个字符串或是一个正则表达式。

 stringObject.replace(regexp/substr,replacement)
  1. 第一个参数: 被替换的字符串 或者 正则表达式
  2. 第二个参数: 替换为的字符串
  3. 返回值是一个替换完毕的新字符串
var str = 'andy和red';
var newStr = str.replace('andy', 'baby');
console.log(newStr)//baby和red
//等同于 此处的andy可以写在正则表达式内
var newStr2 = str.replace(/andy/, 'baby');
console.log(newStr2)//baby和red
//全部替换
var str = 'abcabc'
var nStr = str.replace(/a/,'哈哈')
console.log(nStr) //哈哈bcabc
//全部替换g
var nStr = str.replace(/a/g,'哈哈')
console.log(nStr) //哈哈bc哈哈bc
//忽略大小写i
var str = 'aAbcAba';
var newStr = str.replace(/a/gi,'哈哈')//"哈哈哈哈bc哈哈b哈哈"

3.5.2 正则表达式参数

/表达式/[switch]

switch(也称为修饰符) 按照什么样的模式来匹配. 有三种值:

  1. g:全局匹配
  2. i:忽略大小写
  3. gi:全局匹配 + 忽略大小写

案例:过滤敏感词汇

<textarea name="" id="message"></textarea> <button>提交</button>
<div></div>
<script>var text = document.querySelector('textarea');var btn = document.querySelector('button');var div = document.querySelector('div');btn.onclick = function() {div.innerHTML = text.value.replace(/激情|gay/g, '**');}
</script>

3.5.3 match 提取

字符串.match(正则表达式)可以对字符串进行提取操作,返回值是一个数组。

案例:提取字符串中的邮箱地址

 var str = '我的邮箱是xiaoming@qq.com。:他的邮箱是xiaohong@sina.com。奥利给的邮箱是wuyou@163.com';// 字符串.match(正则表达式)可以对字符串进行提取操作,返回值是一个数组// 提取字符串str中的邮箱内容,注意,需要在正则的最后添加匹配模式g,不要设置严格匹配。var str1 = str.match(/\w+@\w+\.\w+/g)console.log(str1);

4:不一样的“火星文”相关推荐

  1. 在线火星文转换器工具

    在线火星文转换器工具 在线火星文转换器工具 火星文(火星文:焱暒妏),趣味地意指地球人看不懂的文字,由符号.繁体字.日文.韩文.冷僻字或汉字拆分后的部分等非正规化文字符号组合而成. https://t ...

  2. 在线火星文转简体中文工具

    在线火星文转简体中文工具 在线火星文转简体中文工具 火星文(火星文:焱暒妏),趣味地意指地球人看不懂的文字,由符号.繁体字.日文.韩文.冷僻字或汉字拆分后的部分等非正规化文字符号组合而成. https ...

  3. java非主流火星文输入法_我爱火星文_火星文输入法

    火星文输入法是一款火星文即时转换软件,包含火星文转换器和繁体字转换器,支持非主流火星文转换,繁体字转换,菊花文,QQ闪字,在线转换兼容所有中文输入法,是新新人类QQ聊天的必备工具. 火星文输入法,是2 ...

  4. 16.火星文转换 C#

    using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace _08_ ...

  5. 这些00后的“火星文”你都认识吗?证明自己是小鲜肉的时刻终于到了

    还以为自己年少轻狂, 互联网新时代的弄潮儿, 当年用QQ聊天.发说说.空间留言的 [火星文]好像还近在眼前-- 聊天还用着 3Q.886.666.2333的 "90后小鲜肉们", ...

  6. 华为OD机试 - 火星文计算 2(C++) | 附带编码思路 【2023】

    刷算法题之前必看 参加华为od机试,一定要注意不要完全背诵代码,需要理解之后模仿写出,通过率才会高. 华为 OD 清单查看地址:https://blog.csdn.net/hihell/categor ...

  7. java非主流火星文输入法_火星文转换器,火星文转换器在线转换

    火星文转换器在线转换 猫旅人 火星文是什么 火星文转换器怎么转换 你说的这个火星文其实就是一些奇形怪异的字符了,在一些个性签名还有昵称里面会经常看到的一些怪异字符,这类其实就是火星文了. 这种火星文是 ...

  8. javascript 火星文,菊花体,繁体,简体文字转换

    前言:之前在百度应用里面看到了这个过类似的工具,很想知道怎么实现的. 琢磨下,自己写了一个,效果如下. <!-------HTML CODE----------> <!DOCTYPE ...

  9. 火星文输入法?---互联网的主流与非主流

    啥东西都有,火星文输入法? 转自:http://xiaoer-1982.iteye.com/blog/693739 摘自:http://shbbs.soufun.com/1210036594~-1~1 ...

  10. 火星文转换php源码,简体/繁体/火星文转换

    require_once 'curl.func.php'; $appkey = 'your_appkey_here';//你的appkey $content = '今天天气挺好的';//utf8 $t ...

最新文章

  1. 自动驾驶,别再谈「接管」色变了
  2. 深入浅出HTTPS基本原理
  3. mysql adodb_关于从MySQL转向ADODB的方法
  4. 常用的几种简单的内部排序方法
  5. css3玩转各种效果【资源】
  6. springboot的缓存技术
  7. 高中计算机室名言,高中班级激励格言
  8. SQL服务器引擎组件概览
  9. cuda pytorch 环境变量_PyTorch-GPU环境配置
  10. 《统计学习方法》—— 聚类方法(层次聚类和K均值聚类)
  11. 2.FactoryMethod-工厂方法模式
  12. 编译环境 Golang开发环境 vscode+git
  13. 凯恩帝k1000ti参数设置_K1000TII标准程序调试参数说明
  14. PS快速更换照片背景色【一寸照片效果最好】
  15. python抢票软件源代码_一百多行python代码实现抢票助手
  16. 这9个技巧让你的PyTorch模型训练得飞快!
  17. Hadoop安装及hdfs操作
  18. Google Map开发系列(十二)——定制GoogleBar --谷歌地图的本地搜索栏
  19. 计算机网络--2020春-平时小测2--习题答案
  20. Oracle索引详解(索引的原理,创建索引,删除索引,修改索引等)

热门文章

  1. 28个超实用Chrome DevTools 调试技巧参考了前端调试通关秘籍
  2. 超六类网线和六类网线的网口都是一样的吗?
  3. java 调用父级方法_java子类调用父类的方法是什么
  4. 5、如何搭建卫星地图离线地图服务
  5. 2022.2.28总结
  6. 【数据集处理】Python修改图片为.jpg格式批量修改名字为000000格式
  7. 如何通过公网访问私有网盘,天翼网关如何端口转发
  8. 数通笔记IP.1-认识网络设备
  9. 灵魂代码及改造魂魄翻译
  10. python按字符分割_Python:按字符位置分割字符串 - python