正则表达式(RegEx)用于匹配、搜索和处理字符串数据,常见应用场景包括:

应用场景:

  1. 数据验证:如邮箱、电话号码等格式验证。
  2. 文本搜索与替换:批量替换或提取符合特定模式的文本。
  3. 日志解析:分析服务器日志、提取错误信息。
  4. Web爬虫:从HTML中提取URL、标题等信息。

方法与参考案例:

  1. 验证电子邮箱

    const emailPattern = /^[a-zA-Z0-9_.+-]+@[a-zA-Z0-9-]+\.[a-zA-Z0-9-.]+$/;
    const isValidEmail = emailPattern.test('test@example.com');
    
  2. 提取URL中的域名

    const url = 'https://www.example.com';
    const domainPattern = /https?:\/\/(www\.)?([\w-]+\.\w+)/;
    const domain = url.match(domainPattern)[2];
    
  3. 替换文本中的多余空格

    const str = 'This    is a   test';
    const cleanStr = str.replace(/\s+/g, ' ');
    
  4. 固定电话号码验证

    const phonePattern = /^(0\d{2,4}-)?\d{7,8}$/;
    console.log(phonePattern.test('010-9545767'));
    

    5.手机号码验证:

    const isMobile = /^1[3456789]\d{9}$/
    console.log(isMobile .test('18600690930'))
    

    6.身份证格式验证:

    const isIdCard= /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/
    console.log(isIdCard.test('身份证号码'))
    

    7.数字格式验证:

    // 可以是负数,可以是小数
    const isNumber = /^(-)?\d+(\.\d+)?$/
    console.log(isNumber.test(23.33))
    

    8.车牌号格式验证:

    const isCarNo = /^(([京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-Z](([0-9]{5}[DF])|([DF]([A-HJ-NP-Z0-9])[0-9]{4})))|([京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-Z][A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳使领]))$/
    console.log(isCarNo .test('京NBE024'))
    

    9.中文字符验证:

    const isChinese = /^[\u4e00-\u9fa5]+$/
    console.log(isChinese .test('字符串'))
    

    10.是否含有特殊字符验证:

    const isHasSpecialCharacters = /[ ,.!@#\$%^&*\(\)_+\-=\[\]{};':\"\\|<>/]+/
    console.log(isHasSpecialCharacters.test('字符串,'))
    

    11.过滤html标签:

    function stripHtmlTags(str) {
        // 定义正则表达式,匹配HTML标签
        const regex = /<[^>]*>/g;
        // 使用replace方法替换所有匹配到的HTML标签为''
        return str.replace(regex, '');
    }
    
    // 使用示例
    const htmlString = "<p>Hello, <strong>World!</strong></p>";
    const plainText = stripHtmlTags(htmlString);
    
    console.log(plainText); // 输出: "Hello, World!"
    

常用正则表达式的方法还有很多,这里先列举一些项目中经常用到的,后续会持续更新的,欢迎点赞+关注+收藏,需要更多正则表达式欢迎留言,留言必回。

点赞(0) 打赏

评论列表 共有 0 条评论

暂无评论

微信公众账号

微信扫一扫加关注

发表
评论
返回
顶部