正则表达式
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title>
</head>
<body>
<script>
// 正则表达式:匹配字符串中字符组合的模式,查找、替换那些符合正则表达式的文本
// const 变量名=/表达式/其中前后斜杠表示字面量
// regObj.test(被检测的字符串)
// 1.定义规则
const str=/前端/
// 2.是否匹配
regObj.test(str)//布尔型
regObj.exec(str)//检索符合规则的字符串,返回一个数组
//元字符:特殊字符,26个英文字母[a-z]
// 边界符:表示开头结尾
// ^表示匹配行首的文本(以谁开始)
//$表示匹配行尾的文本(以谁结束)
console.log(/^哈/.test('二哈'))//意思是必须以哈开头
console.log(/^哈$/.test('哈'))//必须一哈开头结尾,一个东西
console.log(/^哈$/.test('哈哈'))//false
// 量词:表示重复次数, 设定某个模式只能出现的次数
// *:重复零次或更多次:>=0
console.log(/^哈*$/.test('哈哈'))//true
console.log(/^哈*$/.test(''))//true
console.log(/^哈*$/.test('哈'))//true
console.log(/^哈*$/.test('二哈哈哈'))//false
// +:重复一次或更多次:>=1
// ?:重复零次或者一次:0||1
// {n}:重复n次:写几必须出现几次
// {n,}:重复n次或者更多次:>=n
// {n,m}:重复n到m次:n<=并要<=m.千万不能出现空格
// 字符类:\d表示0~9
// 匹配字符集合[] :任意一个出现就行
console.log(/[abc]/.test('andy'))//任意一个都行
console.log(/^[abc]$/.test('aa'))//只能一个
console.log(/^[abc]{2}$/.test('aa'))//只能一个
console.log(/^[A-Za-z0-9]$/.test('p'))//只能一个
// qq号:^[1-9][0-9]{4,}$(腾讯qq从1000开始)
// 在[]里面^加上表示取反,除了之外
//预定义类:常见的简写模式
// \d:匹配0-9之间任意数字
// \D:0-9以外的字符
// \w:匹配任意字母、数字、下划线
// \W:匹配任意字母、数字、下划线取反
// \s:匹配空格(包括换行符、制表符、空格符等)
// \S:匹配非空格的字符
//日期格式^\d{4}-\d{1,2}-\d{1,2}
//修饰符:是否区分大小写,是否支持多行匹配 /表达式/修饰符
// i:正则匹配时字母不区分大小写
// g:匹配所有满足正则表达式的结果
//字符串.replace(/正则表达式/,'替换的文本')
console.log(/a/i.test('a'))//true
str.replace(/java/i,'前端')//用前端替换java
</script>
</body>
</html>