JavaScript 回顾(六)

78 阅读3分钟

这是我参与更文挑战的第29天,活动详情查看: 更文挑战

1, 正则表达式

正则表达式用于定义一些字符串的规则,用来检查一个字符串是否符合该规则。

(1) 创建正则表达式的对象

var reg = new RegExp("正则表达式",“匹配模式)

有两个参数,第一个参数: 正则表达式, 第二个参数:匹配模式

(2) test()

使用test()方法可以检查一个字符串是否符合正则表达式的规则, 如果符合规则,返回:true, 否则返回:fasle

var str = 'a'
var result = reg.test(str)

(3) 字面量创建正则表达式

语法:var 变量 = /正则表达式/匹配模式

reg = /a/i;

(4) 创建一个正则表达式,检查字符串是否有a或b

使用 | 表示或者的意思

reg = /a|b|c/;

(5) 检查是否有字母

[] 也是或者的意思

reg = /[ab]/

注意: [] 里的内容也是或的关系

[ab] == a|b

[a-z] :表示任意小写字母

[A-Z] : 表示任意大写字母

[A-z] : 表示任意字母

(6) [^ ] 除了

reg = /[^0-9]/   :表示除了数字

2, 字符串匹配正则

(1) split()

可以将一个字符串拆分为一个数组

var str = "a2345c8090"
var result = str.split('c')

根据任意字母来拆分字符串

var result = str.split(/[A-z]/)

(2) search()

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

  • 如果搜索到指定内容,则会返回第一次出现的索引,如果没有搜索到返回-1
  • 它可以接受一个正则表达式作为参数,然后会根据正则表达式去检索字符串
str = "hello abc hello abd";
result = str.search('abcd')
resut 2 = str.search(/a[bdf]c/)

(3)match()

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

  • 默认情况match只会找到第一个符合要求的内容,找到后就停止检索

  • 设置全局匹配模式,就可以匹配到所有的内容

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

  • match() 会将匹配到的内容封装到一个数组返回

    str = "1a2c3f45d4t6y"
    result = str.match(/[a-z]/gi)
    console.log(result)
    

(4) replace()

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

  • 第一个参数:被替换的内容, 可接受一个正则表达式
  • 第二个参数:新的内容
resutl = str.replace('a', '$$')
​
resut2 = str.replace(/[a-z]/gi, '@')

3, 正则量词

(1) 通过设置量词,设置一个内容出现的次数

{n} 正好出现n次

var reg = /a{3}/;  // 表示a出现3次

(2) 出现 m~n次

{m, n}

(3) 出现m次以上

{m,}

(4) n+ :至少一个

相当于:{1,}

(5) n* :0个或者多个

相当于:{0,}

(6) n? :0个或者1个

相当于:{0,1}

4,正则实战

(1) 检查一个字符串中是否以a开头

^a

(2) 检查一个字符串是否以a结尾

a$

reg = /^a/
reg = /a$/
// 匹配以a开,并且以a结束
reg = /^a$/

(3) 检查是否是一个合法的手机号

手机号规则:

  • 以1开头
  • 第二位3~9的任意数组
  • 三位以后任意数字9个
var phoneStrReg = /^1[3-9][0-9]{9}$/;

(4) 转义字符: \

检查.

var reg = /./

(5) w: 任意字母,数字

W:除了字母,数字

(6) 替换空格

var str = "             he  llo      ";
str = str.replace(/\s/g, '')

匹配开头和结尾的空格

str = str.replace(/^\s*|\s*$/, '')

(7) 电子邮件

电子邮件规则

  • 任意字母数字下划线: \W{3,}

  • 任意字母数字下划线 (.\w+)

  • @

  • 任意字母数字 [A-z0-9]+

  • 任意字母(2-5) (.[A-z]{2,5}){1,2}

    var emailRge = /^\W{3,}(.\w+)*@ [A-z0-9]+(.[A-z]{2,5}){1,2}$/
    

注意: . 表示任意字符串