1,000줄의 코드를 절약해 주는 20가지 정규식
正则表达式,一个十分古老而又强大的文本处理工具,仅仅用一段非常简短的表达式语句,便能够快速实现一个非常复杂的业务逻辑。熟练地掌握正则表达式的话,能够使你的开发效率得到极大的提升。
正则表达式经常被用于字段或任意字符串的校验,如下面这段校验基本日期格式的JavaScript代码:
<span class="hljs-keyword">var reg = <span class="hljs-regexp">/^(\\d{1,4})(-|\\/)(\\d{<span class="hljs-number">1,<span class="hljs-number">2})\\<span class="hljs-number">2(\\d{<span class="hljs-number">1,<span class="hljs-number">2})$/; <span class="hljs-keyword">var r = fieldValue.match(reg); <span class="hljs-keyword">if(r==<span class="hljs-literal">null)alert(<span class="hljs-string">'Date format error!');</span></span></span></span></span></span></span></span></span></span></span>
下面是技匠整理的,在前端开发中经常使用到的20个正则表达式。
1 . 校验密码强度
密码的强度必须是包含大小写字母和数字的组合,不能使用特殊字符,长度在8-10之间。
^(?=.<span class="hljs-emphasis">*\\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$</span>
2. 校验中文
字符串仅能是中文。
^[\\u4e00-\\u9fa5]{0,}$
3. 由数字、26个英文字母或下划线组成的字符串
^\\w+$
4. 校验E-Mail 地址
同密码一样,下面是E-mail地址合规性的正则检查语句。
[<span class="hljs-string">\\w!#$%&'*+/=?^_`{|}~-]+(?:\\.[<span class="hljs-string">\\w!#$%&'*+/=?^_`{|}~-]+)<span class="hljs-emphasis">*@(?:[\\w](?:[\\w-]*[<span class="hljs-string">\\w])?\\.)+[<span class="hljs-string">\\w](<span class="hljs-link">?:[\\w-]*[\\w])?</span></span></span></span></span></span>
5. 校验身份证号码
下面是身份证号码的正则校验。15 或 18位。
15位:
^[<span class="hljs-number">1-<span class="hljs-number">9]\\d{<span class="hljs-number">7}((<span class="hljs-number">0\\d)<span class="hljs-params">|(1[0-2]))(([0|<span class="hljs-number">1<span class="hljs-params">|2]\\d)|<span class="hljs-number">3[<span class="hljs-number">0-<span class="hljs-number">1])\\d{<span class="hljs-number">3}$</span></span></span></span></span></span></span></span></span></span></span>
18位:
^[<span class="hljs-number">1-<span class="hljs-number">9]\\d{<span class="hljs-number">5}[<span class="hljs-number">1-<span class="hljs-number">9]\\d{<span class="hljs-number">3}((<span class="hljs-number">0\\d)<span class="hljs-params">|(1[0-2]))(([0|<span class="hljs-number">1<span class="hljs-params">|2]\\d)|<span class="hljs-number">3[<span class="hljs-number">0-<span class="hljs-number">1])\\d{<span class="hljs-number">3}([<span class="hljs-number">0-<span class="hljs-number">9]<span class="hljs-params">|X)$</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
6. 校验日期
“yyyy-mm-dd“ 格式的日期校验,已考虑平闰年。
^(?:(?!0000)[<span class="hljs-string">0-9]{4}-(?:(?:0[<span class="hljs-string">1-9]|1[<span class="hljs-string">0-2])-(?:0[<span class="hljs-string">1-9]|1[<span class="hljs-string">0-9]|2[<span class="hljs-string">0-8])|(?:0[<span class="hljs-string">13-9]|1[<span class="hljs-string">0-2])-(?:29|30)|(?:0[<span class="hljs-string">13578]|1[<span class="hljs-string">02])-31)|(?:[<span class="hljs-string">0-9]{2}(?:0[<span class="hljs-string">48]|[<span class="hljs-string">2468][<span class="hljs-symbol">048]|[<span class="hljs-string">13579][<span class="hljs-symbol">26])|(?:0[<span class="hljs-string">48]|[<span class="hljs-string">2468][<span class="hljs-symbol">048]|[<span class="hljs-string">13579][<span class="hljs-symbol">26])00)-02-29)$</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
7. 校验金额
金额校验,精确到2位小数。
^[0-9]+(.[0-9]{2})?$
8. 校验手机号
下面是国内 13、15、18开头的手机号正则表达式。(可根据目前国内收集号扩展前两位开头号码)
^(<span class="hljs-number">13[<span class="hljs-number">0-<span class="hljs-number">9]<span class="hljs-params">|14[5|<span class="hljs-number">7]<span class="hljs-params">|15[0|<span class="hljs-number">1<span class="hljs-params">|2|<span class="hljs-number">3<span class="hljs-params">|5|<span class="hljs-number">6<span class="hljs-params">|7|<span class="hljs-number">8<span class="hljs-params">|9]|<span class="hljs-number">18[<span class="hljs-number">0<span class="hljs-params">|1|<span class="hljs-number">2<span class="hljs-params">|3|<span class="hljs-number">5<span class="hljs-params">|6|<span class="hljs-number">7<span class="hljs-params">|8|<span class="hljs-number">9])\\d{<span class="hljs-number">8}$</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
9. 判断IE的版本
IE目前还没被完全取代,很多页面还是需要做版本兼容,下面是IE版本检查的表达式。
^.<span class="hljs-emphasis">*MSIE [5-8](?:\\.[0-9]+)?(?!.*Trident\\/[5-9]\\.0).*$</span>
10. 校验IP-v4地址
IP4 正则语句。
\\b(?:(?:25[<span class="hljs-string">0-5]|2[<span class="hljs-string">0-4][<span class="hljs-symbol">0-9]|[<span class="hljs-string">01]?[<span class="hljs-string">0-9][<span class="hljs-symbol">0-9]?)\\.){3}(?:25[<span class="hljs-string">0-5]|2[<span class="hljs-string">0-4][<span class="hljs-symbol">0-9]|[<span class="hljs-string">01]?[<span class="hljs-string">0-9][<span class="hljs-symbol">0-9]?)\\b</span></span></span></span></span></span></span></span></span></span></span></span>
11. 校验IP-v6地址
IP6 正则语句。
(([0-9a<span class="hljs-_">-fA-F]{1,4}:){7,7}[0-9a<span class="hljs-_">-fA-F]{1,4}|([0-9a<span class="hljs-_">-fA-F]{1,4}:){1,7}:|([0-9a<span class="hljs-_">-fA-F]{1,4}:){1,6}:[0-9a<span class="hljs-_">-fA-F]{1,4}|([0-9a<span class="hljs-_">-fA-F]{1,4}:){1,5}(:[0-9a<span class="hljs-_">-fA-F]{1,4}){1,2}|([0-9a<span class="hljs-_">-fA-F]{1,4}:){1,4}(:[0-9a<span class="hljs-_">-fA-F]{1,4}){1,3}|([0-9a<span class="hljs-_">-fA-F]{1,4}:){1,3}(:[0-9a<span class="hljs-_">-fA-F]{1,4}){1,4}|([0-9a<span class="hljs-_">-fA-F]{1,4}:){1,2}(:[0-9a<span class="hljs-_">-fA-F]{1,4}){1,5}|[0-9a<span class="hljs-_">-fA-F]{1,4}:((:[0-9a<span class="hljs-_">-fA-F]{1,4}){1,6})|:((:[0-9a<span class="hljs-_">-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a<span class="hljs-_">-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a<span class="hljs-_">-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))</span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span></span>
12. 检查URL的前缀
应用开发中很多时候需要区分请求是HTTPS还是HTTP,通过下面的表达式可以取出一个url的前缀然后再逻辑判断。
<span class="hljs-keyword">if (!s.match(<span class="hljs-regexp">/^[a-zA-Z]+:\\/\\<span class="hljs-comment">//)) { s = <span class="hljs-string">'http://' + s; }</span></span></span></span>
13. 提取URL链接
下面的这个表达式可以筛选出一段文本中的URL。
^(f|ht){<span class="hljs-number">1}(tp|tps):\\<span class="hljs-regexp">/\\/([\\w-]+\\.)+[\\w-]+(\\/[\\w- ./?%&=]*)?</span></span>
14. 文件路径及扩展名校验
验证windows下文件路径和扩展名(下面的例子中为.txt文件)
^([a-zA-Z]\\<span class="hljs-symbol">:|\\\\)\\\\([^\\\\]+\\\\)*[^\\/<span class="hljs-symbol">:*?<span class="hljs-string">"<>|]+\\.txt(l)?$</span></span></span>
15. 提取Color Hex Codes
有时需要抽取网页中的颜色代码,可以使用下面的表达式。
^<span class="hljs-comment">#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$</span>
16. 提取网页图片
假若你想提取网页中所有图片信息,可以利用下面的表达式。
\\<span class="xml"><span class="hljs-tag">< *[<span class="hljs-attr">img][^\\\\>]<span class="hljs-emphasis">*[src] *= <span class="hljs-emphasis">*[\\"\\']{0,1}([^\\"\\'\\ >]*)</span></span></span></span></span>
17. 提取页面超链接
提取html中的超链接。
(<a\\<span class="hljs-keyword">s*(?!.*\\brel=)[^>]*)(href=<span class="hljs-string">"https?:\\/\\/)((?!(?:(?:www\\.)?'.implode('|(?:www\\.)?', $follow_list).'))[^"]+)<span class="hljs-string">"((?!.*\\brel=)[^>]*)(?:[^>]*)></span></span></span>
18. 查找CSS属性
通过下面的表达式,可以搜索到相匹配的CSS属性。
^\\s*[a-zA-Z\\-]+\\s*[:]{<span class="hljs-number">1}\\s[a-zA-Z0<span class="hljs-number">-9\\s.<span class="hljs-comment">#]+[;]{1}</span></span></span>
19. 抽取注释
如果你需要移除HMTL中的注释,可以使用如下的表达式。
<span class="hljs-comment"><!--(.*?)--></span>
20. 匹配HTML标签
通过下面的表达式可以匹配出HTML中的标签属性。
<\\/?\\w+((\\s+\\w+(\\s*=\\s*(?<span class="hljs-symbol">:<span class="hljs-string">".*?"|<span class="hljs-string">'.*?'|[\\^<span class="hljs-string">'">\\s]+))?)+\\s*|\\s*)\\/?></span></span></span></span>
正则表达式的相关语法
下面是我找到的一张非常不错的正则表达式 Cheat Sheet,可以用来快速查找相关语法。

学习正则表达式
我在网上看到了一篇相当不错的正则表达式快速学习指南,有兴趣继续深入学习的同学可以参考。

正则表达式在线测试工具
regex101是一个非常不错的正则表达式在线测试工具,你可以直接在线测试你的正则表达式哦。


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











HTML은 간단하고 배우기 쉽고 결과를 빠르게 볼 수 있기 때문에 초보자에게 적합합니다. 1) HTML의 학습 곡선은 매끄럽고 시작하기 쉽습니다. 2) 기본 태그를 마스터하여 웹 페이지를 만들기 시작하십시오. 3) 유연성이 높고 CSS 및 JavaScript와 함께 사용할 수 있습니다. 4) 풍부한 학습 리소스와 현대 도구는 학습 과정을 지원합니다.

HTML은 웹 구조를 정의하고 CSS는 스타일과 레이아웃을 담당하며 JavaScript는 동적 상호 작용을 제공합니다. 세 사람은 웹 개발에서 의무를 수행하고 화려한 웹 사이트를 공동으로 구축합니다.

WebDevelopmentReliesonHtml, CSS 및 JavaScript : 1) HtmlStructuresContent, 2) CSSSTYLESIT, 및 3) JAVASCRIPTADDSINGINTERACTIVITY, BASISOFMODERNWEBEXPERIENCES를 형성합니다.

anexampleStartingtaginhtmlis, whithbeginsaparagraph.startingtagsareessentialinhtmlastheyinitiate rements, definetheirtypes, andarecrucialforstructurituringwebpages 및 smanstlingthedom.

GiteEpages 정적 웹 사이트 배포 실패 : 404 오류 문제 해결 및 해결시 Gitee ...

이미지를 클릭 한 후 주변 이미지를 산란 및 확대하는 효과를 얻으려면 많은 웹 디자인이 대화식 효과를 달성해야합니다. 특정 이미지를 클릭하여 주변을 만들 수 있습니다 ...

웹 주석 기능에 대한 Y 축 위치 적응 알고리즘이 기사는 Word 문서와 유사한 주석 기능을 구현하는 방법, 특히 주석 간격을 다루는 방법을 모색합니다 ...

HTML, CSS 및 JavaScript는 웹 개발의 세 가지 기둥입니다. 1. HTML은 웹 페이지 구조를 정의하고 등과 같은 태그를 사용합니다. 2. CSS는 색상, 글꼴 크기 등과 같은 선택기 및 속성을 사용하여 웹 페이지 스타일을 제어합니다.
