1 正则表达式(英语:Regular Expression)

正则表达式(英语:Regular Expression,在代码中常简写为regex、regexp或RE)使用单个字符串来描述、匹配一系列符合某个句法规则的字符串搜索模式。搜索模式可用于文本搜索和文本替换。

2 什么是正则表达式?

正则表达式是由一个字符序列形成的搜索模式。

当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容。

正则表达式可以是一个简单的字符,或一个更复杂的模式。

正则表达式可用于所有文本搜索和文本替换的操作。

3 正则表达式的特点是:

灵活性、逻辑性和功能性非常的强;

可以迅速地用极简单的方式达到字符串的复杂控制。

对于刚接触的人来说,比较晦涩难懂。

4  正则表达式声明

-1 通过构造函数定义

var 变量名= new RegExp(/表达式/);

-2 通过直接量定义(较为常用)

var 变量名= /表达式/;

console.log(regexp1.test(345));

console.log(/\d/.test(567));(直接使用)

-3 正则表达式的组成是:(总结)

有一些普通字符和元字符组成,普通字符就是字母和数字,元字符具有特殊意义的字符

5 正则表达式方法

-1 test() 方法

正则对象方法,检测测试字符串是否符合该规则,返回true和false,参数(测试字符串)

使用语法:

Boolean = 表达式.test("要验证的内容");

6 正则内部类

-1 预定义类

[^\n\r] 除了换行和回车之外的任意字符(“”不行)

\d [0-9] 数字字符

\D [^0-9]    非数字字符

\s [ \t\n\x0B\f\r]  空白字符

\S [^ \t\n\x0B\f\r]  非空白字符

\w [a-zA-Z_0-9]  单词字符

\W [^a-zA-Z_0-9]     非单词字符

-2  简单类(正则://中什么特殊符号都不写,和[]的加入)

1、/string/.test(“string”);            必须是完整的,只多不能少

/andy/.test(“andy”) // true

/andy/.test(“andylv”)   // true

/andy/.test(“an”)   // false

一句话,只要完整包含了andy 就可以了(有他就行)

2、/[string]/.test(“string”);    只要包含里面的任何一个就可以

/[andy]/.test("andy");   // true

/[andy]/.test("an"); // true

/[andy]/.test("ady"); // true

/[andy]/.test("anll"); // true

/[andy]/.test("assd"); // true

/[andy]/.test("ss"); // false

/[3aH8]/.test("ss"); // false

-3  负向类(不能是其中的整体或者一部分)

中括号内,前面加个元字符^进行取反,不是括号里面的字符(一部分也不行)。

(可以不够,但是不能多)(不够和正好,返回false;多了或者没有返回true)

console.log(/[^abc]/.test('a'));

console.log(/[^abc]/.test('gg'));

注意:  这个符号 ^  一定是写到方括号里面

-4 范围类

有时匹配的东西过多,而且类型又相同,全部输入太麻烦,我们可以在中间加了个横线

console.log(/[a-z]/.test('1111'));

console.log(/[A-Z]/.test('aa'));

-5 组合类

用中括号匹配不同类型的单个字符。

console.log(/[a-m1-5]/.test("b"))//true

6 正则边界

^ 会匹配行或者字符串的起始位置

注:^在[]中才表示非!这里表示开始

$ 会匹配行或字符串的结尾位置

^$在一起 表示必须是这个(精确匹配)

// 边界可以精确说明要什么
console.log(/lily/.test("lilyname")); // true
console.log(/^lily$/.test("lily")); // true
console.log(/^lily$/.test("ly")); // false

console.log(/^andy$/.test("andy"));  // true

这个的最终意思就是 说, 必须是 andy 这四个字母

7 量词

(多个字母,重复最后一个)

*   (贪婪)   重复零次或更多   (>=0)

+   (懒惰)   重复一次或更多次  (>=1)

?    (占有)   重复零次或一次   (0||1)  要么有 要么没有

{}  重复多少次的意思   可以有多少个

您的银行卡密码只能是 6位      {6}

{n} n次 (x=n)

{n,} 重复n次或更多  (x>=n)

{n,m} 重复出现的次数比n多但比m少 (n<=x<=m)

*     {0,}

+     {1,}

?     {0,1}

x|y    一个 |   x  或者 y(没有&,用的是,代替的)

()提高权限,有限计算

8 replace 函数

replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

语法格式:(返回值是新字符串)

需要匹配的对象.replace(正则式/字符串,替换的目标字符)

正则表达式的匹配模式支持的2个标志

g:表示全局模式(global),即模式将被应用于所有字符串而非发现一个而停止

i:表示不区分大小写(ease-insensitive)模式,在确定匹配想时忽略模式与字符串的大小写

javascript总结48:正则表达式(RegExp)的更多相关文章

  1. JavaScript学习笔记-正则表达式(RegExp对象)

    正则表达式(RegExp对象)   1.正则表达式字面量,在脚本加载后编译.若你的正则表达式是常量,使用这种方式可以获得更好的性能,重复使用时不会重新编译: 2.使用构造函数创建的RegExp,提供了 ...

  2. 从javaScript中学习正则表达式——RegExp

    正则表达式工具:http://regexper.com   由于国外网络可以选择 https://github.com/javallone/regexper-static 离线安装作为本地服务. 正则 ...

  3. javascript类型系统——正则表达式RegExp类型

    × 目录 [1]对象 [2]实例属性 [3]静态属性[4]实例方法 前面的话 前面已经介绍过javascript中正则表达式的基础语法.javascript的RegExp类表示正则表达式,String ...

  4. JavaScript数据类型 正则表达式RegExp类型

    前言 上一篇文章已经介绍了正则表达式的基础语法.javascript的RegExp类表示正则表达式,String和RegExp都定义了方法,使用正则表达式可以进行强大的模式匹配和文本检索与替换.本文将 ...

  5. JavaScript -- 时光流逝(六):js中的正则表达式 -- RegExp 对象

    JavaScript -- 知识点回顾篇(六):js中的正则表达式 -- RegExp 对象 1. js正则表达式匹配字符之含义      查找以八进制数 规定的字符.     查找以十六进制数 规定 ...

  6. JavaScript 正则表达式RegExp 和字符串本身的正则表达式

    JavaScript 正则表达式 正则表达式(英语:Regular Expression,在代码中常简写为regex.regexp或RE)使用单个字符串来描述.匹配一系列符合某个句法规则的字符串搜索模 ...

  7. JavaScript中的正则表达式(终结篇)

    JavaScript中的正则表达式(终结篇) 在之前的几篇文章中,我们了解了正则表达式的基本语法,但那些语法不是针对于某一个特定语言的.这篇博文我们将通过下面几个部分来了解正则表达式在JavaScri ...

  8. Javascript中的正则表达式

    Javascript中的正则表达式 刚开始接触正则表达式的时候,觉得这是个很死板的东西(没办法,计算机不能像人眼一样能很快的辨认出我们需要的结果,它需要一定的规则来对它进行限制),了解的越多,发现这个 ...

  9. 浅谈JavaScript中的正则表达式

    引言 对于正则表达式我想作为程序员肯定使用过它,那天书般的表达方式,我用一次就记住它了.这篇博客先介绍一些正则表达式的内容,然后介绍JavaScript中对正则表达式特有的改进.下面开始介绍正则表达式 ...

随机推荐

  1. ALSA声卡12_从零编写之添加音量控制_学习笔记

    1.设置音量时应用程序的调用过程 (1)strace分析: amixer cset numid=1 30 (设置音量) /dev/snd/controlC0 open SNDRV_CTL_IOCTL_ ...

  2. node的close

    在http.ServerResponse对象的end方法被调用之前,如果连接被中断,将触发http.ServerResponse对象的close事件. var http=require("h ...

  3. 【BZOJ】1441 Min(数学)

    题目 传送门:QWQ 分析 裴蜀定理. 因为存在 $ a_1 $ $ a_2 $...... $ a_n $的最大公约数为 $ d $,那么必定存在 $ x_1*a_1+x_2*a_2+...x_n* ...

  4. Android屏幕适配方案——基于最小宽度(Smallest-width)限定符

    转自:https://www.cnblogs.com/error404/p/3815739.html 一.关于布局适配建议 1.不要使用绝对布局 2.尽量使用match_parent 而不是fill_ ...

  5. Android复杂自定义Listview实现

    在Android中实现Listview对新人来说比较难以理解,本人看了若干文章后觉得可以使用以下思路来让新人更好理解(同时也做好记录,免得自己以后忘记). 可参考博客:http://cinderell ...

  6. pycharm git工具与coding.net结合

    前提:coding.net中的项目是私密项目 问题描述:在使用pycharm自带的git工具clone(或者push)代码时出现 错误如下:Push failed: Failed with error ...

  7. leetcode36

    public class Solution { public bool IsValidSudoku(char[,] board) { ; i < ; i++) { var dic = new D ...

  8. JSTL之C标签的用法

    转自:https://my.oschina.net/zimingforever/blog/78980 最近开始整理以前的onenote,居然有200多篇,大致翻了下,很多内容都是在大学的时候学习的时候 ...

  9. Unknown picture file extension

    Image1.Picture.LoadFromFile('aaa.jpg'); Project Project1.exe raised exception class EInvalidGraphic ...

  10. 《Apache Velocity用户指南》官方文档

    http://ifeve.com/apache-velocity-dev/ <Apache Velocity用户指南>官方文档 原文链接   译文连接 译者:小村长  校对:方腾飞 Qui ...