当前位置:   article > 正文

【JavaScript】如何使用正则表达式_javascript使用正则

javascript使用正则


一、正则表达式是什么?

正则表达式是用于匹配字符串中字符组合的模式,在JS中也是对象。
在JS中的实例有验证表单(如用户名表单限制用户只能输入字母和数字),过滤内容中的敏感词汇等
常用正则表达式参考https://tool.oschina.net/regex

二、正则表达式的使用

1.正则表达式对象和方法

定义一个正则表达式对象reg,其模式为匹配字符串中出现的"老虎"。
其中/ /是正则表达式字面量(表达一个固定值的表示法,又叫常量)

const str = '两只老虎两只老虎跑得快'
        // 定义规则
        const reg = /老虎/
  • 1
  • 2
  • 3

test()方法,用来查看正则表达式与指定字符串是否匹配,其中返回值用来表示是否匹配,如果匹配返回true,不匹配返回false

reg.test(str) //true
  • 1

利用正则表达式reg去匹配字符串str,然后在控制台输出匹配结果的布尔值。
exec()方法,在一个指定字符串中执行一个搜索匹配

reg.exec(str) // 返回一个数组
  • 1

如果匹配成功返回一个数组,否则返回null
在这里插入图片描述

2.元字符

元字符又叫特殊字符,是一些具有特殊含义的字符,匹配功能比普通字符更强大
限制用户输入26个字母,元字符[a-z]=abcdefg…
限制用户输入0-9的数字,元字符[0-9]=1234567890

(1)边界符

更加精确,表示位置,必须用什么开头或用什么结尾
/^1/表示以1开头

console.log(/^1/.test(123456)) //true
  • 1

/6$/表示以6结尾

console.log(/6$/.test(123456)) //true
  • 1

/^1$/精确匹配1,不能重复

console.log(/^1$/.test(111)) //false
  • 1

(2)量词

表示重复次数,实例有验证码(6位)
*表示重复零次或更多次

console.log(/^1*$/.test(111111)) //true
  • 1

+表示重复一次或更多次

console.log(/^1+$/.test(111111)) //true
  • 1

?表示重复零次或一次

console.log(/^1?$/.test(1)) //true
  • 1

{n}表示重复n次

console.log(/^1{6}$/.test('111111')) //true
  • 1

{n,}表示重复n次或更多次

console.log(/^1{6,}$/.test('1111111')) //true
  • 1

{n,m}表示重复n到m次

console.log(/^1{6,8}$/.test('1111111')) //true
  • 1

(3)字符类

简化,比如\d表示0-9
[abc]匹配a或b或c

 console.log(/[abc]/.test('apple')) //true
 console.log(/[abc]/.test('book'))  //true
  • 1
  • 2

[a-z]表示a到z的字母,[a-zA-Z]表示a到z的大小写字母
[1-9][0-9]{4,}表示qq号

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读