JS正则表达式实战:从数字到地址的全面解析

需积分: 10 0 下载量 174 浏览量 更新于2024-07-24 收藏 284KB PDF 举报
在JavaScript编程中,正则表达式是一种强大的工具,用于处理字符串的各种操作,如匹配、查找、替换和验证。本篇内容将涵盖多个实用的正则表达式案例,帮助开发者解决实际开发中的问题。 1. 匹配结尾的数字:正则表达式`/\d+$/g`可以用来从字符串中提取最后出现的一组数字。例如,从"30CAC0040"中提取"40",从"3SFASDF92"中提取"92",这在处理编号或序列号时非常有用。 2. 统一空格个数:当字符串中的空格数量不一致时,可以使用`\s+/g`正则匹配所有连续的空格,并替换为一个空格。如上所述,通过脚本`var reg = /\s+/g; str = str.replace(reg, "");`将"蓝色理想"中的多余空格去除。 3. 判断字符串是否由数字组成:正则表达式`/^\d*$|^\d+(\.\d+)?$`可以检查字符串是否只包含数字(整数或小数)。它会检查字符串的开始和结束是否都是数字,包括小数点。 4. 电话号码正则:对于电话号码的验证,可能涉及到区号、固定电话和移动电话的不同格式,可以编写不同的正则来匹配这些模式。 5. 删除字符串中的空格:使用`replace(/\s/g, "")`可以快速移除字符串中的所有空格,这对于清理用户输入或格式化输出很有帮助。 6. 限制输入格式:正则表达式可以用于创建输入验证,例如限制文本框只能输入数字和小数点,确保数据格式正确。 7. 匹配中文字符:为了只匹配中文字符,可以使用`\u4e00-\u9fa5`,这是一个Unicode范围,涵盖了所有的汉字。 8. IP地址处理:正则表达式可以匹配IP地址的前三段,如`/^(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/`。 9. HTML标签处理:正则可以匹配`<ul>`与`</ul>`之间的内容,用于提取或替换HTML结构中的部分片段。 10. 文件名获取:从URL或文本中提取文件名,通常涉及到查找最后的`/\w+\.\w+$/`这样的模式。 11. 路径转换:正则可以将绝对路径转换为相对路径,根据上下文进行调整。 12. 用户名验证:设计复杂的正则规则来验证用户名,确保符合特定格式和规则,比如长度限制、特殊字符限制等。 13. 价格匹配:识别并提取价格信息,如`\d+(\.\d{1,2})?`,可以匹配数字和小数。 14. 身份证号码验证:根据不同国家和地区身份证号码的规则,编写相应的正则表达式来匹配和验证。 15. 文本格式化:如单词首字母大写,`/(.)(?=\S)/g`可以实现这个功能。 16. 日期格式验证:正则可以用于检查日期是否符合特定格式,如`/^\d{4}-\d{2}-\d{2}$/`。 17. 文件后缀名处理:移除文件名的后缀或替换后缀,使用`/(.*?).(\.\w+)$/`这样的模式。 18. 邮箱验证:设计复杂的正则表达式来确认电子邮件地址的格式,如`/^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/`. 19. 链接匹配:无论是全匹配还是部分匹配,正则都可以用于查找和替换HTML中的链接。 20. HTML标签检查:检查标签是否闭合,或者获取指定标签内的内容,涉及到嵌套标签的解析。 21. 文本分割和转换:根据特定规则(如标签、换行符)对文本进行分割,或转换标签格式。 22. 添加/修改HTML属性:正则可以用于搜索和替换HTML属性中的内容,如添加双引号或修改特定属性值。 23. 表格处理:在表格(`<table>`)元素上添加缺失的`<tbody>`标签,确保结构完整。 24. 删除/替换标签属性:针对特定标签,移除所有属性或替换特定属性值。 25. 文本高亮显示:使用正则表达式来标记或替换需要高亮的文本。 26. 标签删除:移除整个HTML标签及其内容,可以使用`/<(.*?)>/g`来匹配并删除。 27. 正则学习资源:这部分总结了本文档和其他资源中的各种正则表达式案例,供读者参考和学习。 以上就是关于JavaScript正则表达式案例的详细介绍,它们涵盖了从基础操作到高级功能的广泛应用场景,希望对提高开发者的工作效率有所帮助。