JS正则表达式

JS当初被创建的时候时被用来做表单验证的,正则表达式就是专门做这个的。
对用户输入的信息做校验,不合格的信息就不发给后端。
匹配
替换
提取

创建正则表达式
正则表达式也是对象

  1. 通过调用 RegExp 对象的构造函数创建
    var 变量名 = new RegExp(/表达式/);
  2. 通过字面量创建
    var 变量名 = /表达式/;

检测正则表达式
regexObj.test(str)
regexObj是正则表达式
str是要被检测的字符串
返回一个布尔值true或者false

符号
在这里插入图片描述

<script>
        // 边界符 ^ $ 
        var rg = /abc/; // 正则表达式里面不需要加引号 不管是数字型
        //还是字符串型
        // /abc/ 只要包含有abc这个字符串返回的都是true
        console.log(rg.test('abc'));//true
        console.log(rg.test('abcd'));//true
        console.log(rg.test('aabcd'));//true
        console.log('---------------------------');
        var reg = /^abc/;
        console.log(reg.test('abc')); // true
        console.log(reg.test('abcd')); // true
        console.log(reg.test('aabcd')); // false
        console.log('---------------------------');
        var reg1 = /^abc$/; // 精确匹配 要求必须是 abc字符串才符合规范
        console.log(reg1.test('abc')); // true
        console.log(reg1.test('abcd')); // false
        console.log(reg1.test('aabcd')); // false
        console.log(reg1.test('abcabc')); // false
    </script>

量词
在这里插入图片描述

<script>
        //var rg = /abc/;  只要包含abc就可以 
        // 字符类: [] 表示有一系列字符可供选择,只要匹配其中一个就可以
        var rg = /[abc]/; // 只要包含有a 或者 包含有b 或者包含有c 都
        				//	返回为true
        console.log(rg.test('andy'));//true
        console.log(rg.test('baby'));//true
        console.log(rg.test('color'));//true
        console.log(rg.test('red'));//false
        var rg1 = /^[abc]$/; // 三选一 只有是a 或者是 b  或者是c 
       						 //这三个字母才返回 true
        console.log(rg1.test('aa'));//false
        console.log(rg1.test('a'));//true
        console.log(rg1.test('b'));//true
        console.log(rg1.test('c'));//true
        console.log(rg1.test('abc'));//false
        console.log('------------------');

        var reg = /^[a-z]$/; // 26个英文字母任何一个字母返回 true 
        					// - 表示的是a 到z 的范围  
        console.log(reg.test('a'));//true
        console.log(reg.test('za'));//false
        console.log(reg.test(1));//false
        console.log(reg.test('A'));//false
        // 字符组合
        var reg1 = /^[a-zA-Z0-9_-]$/; // 26个英文字母(大写和小写都可
        							//以)任何一个字母返回 true  
        console.log(reg1.test('a'));//true
        console.log(reg1.test('B'));//true
        console.log(reg1.test(8));//true
        console.log(reg1.test('-'));//true
        console.log(reg1.test('_'));//true
        console.log(reg1.test('!'));//false
        console.log('----------------');
        // 如果中括号里面有^ 表示取反的意思 千万和 我们边界符 ^ 别混淆
        var reg2 = /^[^a-zA-Z0-9_-]$/;
        console.log(reg2.test('aa'));//false
        console.log(reg2.test('B'));//false
        console.log(reg2.test(8));//false
        console.log(reg2.test('-'));//false
        console.log(reg2.test('_'));//false
        console.log(reg2.test('!'));//true
    </script>

预定义类
在这里插入图片描述

<script>
        // 量词符: 用来设定某个模式出现的次数
        // 简单理解: 就是让下面的a这个字符重复多少次
        // var reg = /^a$/;


        //  * 相当于 >= 0 可以出现0次或者很多次 
        // var reg = /^a*$/;
        // console.log(reg.test(''));true
        // console.log(reg.test('a'));true
        // console.log(reg.test('aaaa'));true



        //  + 相当于 >= 1 可以出现1次或者很多次
        var reg = /^a+$/;
        console.log(reg.test('')); // false
        console.log(reg.test('a')); // true
        console.log(reg.test('aaaa')); // true

        //  ?  相当于 1 || 0
        // var reg = /^a?$/;
        // console.log(reg.test('')); // true
        // console.log(reg.test('a')); // true
        // console.log(reg.test('aaaa')); // false

        //  {3 } 就是重复3次
        // var reg = /^a{3}$/;
        // console.log(reg.test('')); // false
        // console.log(reg.test('a')); // false
        // console.log(reg.test('aaaa')); // false
        // console.log(reg.test('aaa')); // true
        //  {3, }  大于等于3
        // var reg = /^a{3,}$/;
        // console.log(reg.test('')); // false
        // console.log(reg.test('a')); // false
        // console.log(reg.test('aaaa')); // true
        // console.log(reg.test('aaa')); // true
        // //  {3,16}  大于等于3 并且 小于等于16
        // var reg = /^a{3,6}$/;
        // console.log(reg.test('')); // false
        // console.log(reg.test('a')); // false
        // console.log(reg.test('aaaa')); // true
        // console.log(reg.test('aaa')); // true
        // console.log(reg.test('aaaaaaa')); // false
    </script>

括号总结

<script>
        // 中括号 字符集合.匹配方括号中的任意字符. 
        // var reg = /^[abc]$/;
        // var reg = /^[abc]{3}$/;abb true; aaa true; aa false;
        // a 也可以 b 也可以 c 可以  a ||b || c
        // 大括号  量词符. 里面表示重复次数
        // var reg = /^abc{3}$/; // 它只是让c重复三次   abccc
        // console.log(reg.test('abc'));
        // console.log(reg.test('abcabcabc'));
        // console.log(reg.test('abccc'));

        // 小括号 表示优先级
        var reg = /^(abc){3}$/; // 它是让abcc重复三次
        console.log(reg.test('abc'));
        console.log(reg.test('abcabcabc'));
        console.log(reg.test('abccc'));
    </script>

替换
replace() 方法可以实现替换字符串操作,用来替换的参数可以是一个字符串或是一个正则表达式。
stringObject.replace(regexp/substr,replacement)

  1. 第一个参数: 被替换的字符串 或者 正则表达式

  2. 第二个参数: 替换为的字符串

  3. 返回值是一个替换完毕的新字符串

    /表达式/[switch] ,这个是写在第一个参数后的
    switch(也称为修饰符) 按照什么样的模式来匹配. 有三种值:
    g:全局匹配 (不加g默认只匹配第一个)(激情 -> ##)(激情激情 -> ##激情)就只会变一个,加了g (激情激情 -> ####)
    i:忽略大小写
    gi:全局匹配 + 忽略大小写

<body>
    <textarea name="" id="message"></textarea> <button>提交</button>
    <div></div>
    <script>
        // 替换 replace
        // var str = 'andy和red';
        // // var newStr = str.replace('andy', 'baby');
        // var newStr = str.replace(/andy/, 'baby');
        // console.log(newStr);
        var text = document.querySelector('textarea');
        var btn = document.querySelector('button');
        var div = document.querySelector('div');
        btn.onclick = function () {
            div.innerHTML = text.value.replace(/激情|gay/g, '**');
        }										//这里加的g
    </script>
</body>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值