js中的正则表达式

  1. 什么是 RegExp:

正则表达式描述了字符的模式对象。

当您检索某个文本时,可以使用一种模式来描述要检索的内容。RegExp 就是这种模式。

简单的模式可以是一个单独的字符。

更复杂的模式包括了更多的字符,并可用于解析、格式检查、替换等等。

您可以规定字符串中的检索位置,以及要检索的字符类型,等等。

  1. 语法:

var 变量=new RegExp("正则表达式","匹配模式");

  1. RegExp 修饰符(匹配模式):

修饰符用于执行不区分大小写和全文的搜索。

i - 修饰符是用来执行不区分大小写的匹配。

g - 修饰符是用于执行全文的搜索(而不是在找到第一个就停止查找,而是找到所有的匹配)。

m - 执行多行匹配。

  1. 方括号:

[abc] - 查找方括号之间的任何字符。

[0-9] - 查找任何从 0 至 9 的数字。

[a-z] - 查找任何从小写 a 到小写 z 的字符。

[A-Z] - 查找任何从大写 A 到大写 Z 的字符。

[A-z] - 查找任何从大写 A 到小写 z 的字符。(包含大小写)

[^输入不查询的内容] – 取反

  1. 元字符

. - 查找单个字符,除了换行和行结束符。

\w 匹配任意字母、数字、"_" 下划线  ==》 [A-z0-9_]

\W 匹配除了字母、数字、"_" 下划线  ==》 [^A-z0-9_]

\d 匹配数字[0-9]

\D 除了数字[^0-9]的任意字符

\s 匹配空格

\S 匹配除了空格的任意字符

\b 匹配单词边界

\B 匹配非单词边界。

\w - 查找单词字符。

  1. 量词:

- 通过量词可以设置一个内容出现的次数

- 量词只对它前面一个内容起作用

- {n} 出现n次

- {m,n} 出现m次到n次

- {n,} 出现n次以上

- + 至少出现一次

- * 出现零次或则零次以上

- ? 出现一次或则零次

  1. RegExp 对象方法:

compile - 编译正则表达式。

test() - 方法搜索字符串指定的值,根据结果并返回真或假。

exec() - 方法检索字符串中的指定值。返回值是被找到的值。如果没有发现匹配,则返回 null。

  1. 支持正则表达式的String对象的方法:

search()  - 检索与正则表达式相匹配的值。

match()   - 找到一个或多个正则表达式的匹配。

replace() - 替换与正则表达式匹配的子串。

split()   - 把字符串分割为字符串数组。

  1. search():

- 可以搜索字符串中是否含有指定内容

- 如果搜索到指定内容,则会返回第一次出现的索引,如果没有搜索到到返回-1

- 它可以接受一个正则表达式作为参数,然后会根据正则表达式去检索字符串

- serach() 只会查找第一个,即使设置全局匹配也没用

a. 代码

var str = "hi,him,his,history"; //字符串

var result = str.search(/hi/); //检测

0 //结果

  1. macth():

- 可以根据正则表达式,从一个字符串中将符合条件的内容提取出来

- 默认情况下我们的macth只会找到第一个符合要求的内容,找到以后就停止检索

 我们可以设置正则表达式为全局匹配模式,这样就会匹配到所有的内容

 可以为一个正则表达式设置多个匹配模式,且顺序无所谓

- match()会将匹配到的内容封装到一个数组中返回,即使只查询到一个结果

a. 代码

var str = "2234sdfsd汉斯234sddfASDADS"; //字符串

var result = str.match(/[a-z]/ig); //检测

["s", "s", "d", "s", "S"] //结果

  1. replace():

- 可以将字符串中指定内容替换为新的内容

- 参数说明:

1.被替换的内容

2.新的内容

    a. 代码

str="hi,him,his,history"; //字符串

esult=str.replace(/,/g,"^_^"); //检测

hi^_^him^_^his^_^history //结果

  1. split():

- 把字符串分割为字符串数组。

- 该方法可以传递一个正则表达式作为参数,这样方法将会根据正则表达式去拆分

    - 该方法即使不指定全局匹配,也会全部拆分字符串

    a. 代码

    var str = "1h3,h5h6 "; //字符串

    var result = str.split(/[a-z]/i); //检测

    ["1", "3,", "5", "6"]  //结果

  1. 开始结尾:

^ - 表示开始

$ - 表示结尾

  1. 例:

手机号的规则:

3893443823(11位)

1. 以1开始

2. 第二位(3-9)

3. 第三位以后任意9个数字

正则:

         reg = /^1[3-9][0-9]{9}$/;

检测字符串:

    使用对象方法: test()

     检测 - Bool = reg.test("1380922568512")

     结果 – true

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值