정규식은 아무리봐도 내가 작성하기가 너무 힘들어,,
라는 생각으로 정리하게 되었답니다~
정규표현식이란?
- 정규 표현식, 또는 정규식은 문자열에서 특정 문자 조합을 찾기 위한 패턴입니다.
- 장점으로는 문자열 처리에 최적
- 단점으로는 가독성이 떨어짐
이메일, 비밀번호, 아이디, 닉네임, 숫자 콤마 등등 정규식은 대체로 많이 이용하게 되는데요
프론트엔드라면 이에 해당하는 정규식, 더 나아가서 유효성 검사까지 구현해낼줄 알아야해요
// RegExp 객체를 이용하는 방법
const regex = new RegExp(pattern, flag);
ex) const regex = new RegExp(pattern, 'g');
// 객체초기화 방법
const regex = /pattern?/flag;
ex) const regex = /pattern?/g;
+) flag
g
(global) (패턴에 매치되는 모든 문자열)m
(multiline) (행이 바뀌어도 찾기)i
(ignoreCase) (대소문자를 구분하지않으며 매치된 첫 문자열)|
(또는) : /Hi | Hello/gm
()
(그룹 지정) : /(Hi | Hello) | (And)/gm
(?:)
(그룹 미지정, 찾지만 기억하지는 않음) : /gr(?:a|e)y/gm
[]
(괄호 안의 어떤 문자든 찾아라) : /gr[ae]y/gm /gr[a-f]y/gm /[a-zA-Z0-9]/gm
[^]
(괄호 안의 어떤 문자든 제외하고 찾아라) : /[^a-z]/gm
?
(없거나 있거나) : /gra?y/gm
a가 있거나 없거나 (gray / gry)*
(없거나 있거나 많거나) : /gra*y/gm
(gry / gray / graay / graaay)+
(하나 또는 많이) : /gra+y/gm
(gray / graay / graaay){n}
(n번 반복) : /gra{2}y/gm
{n,}
(최소 n번 이상) : /gra{2,}y/gm
{n, m}
(최소 n번 이상, m번 이하) : /gra{2,3}y/gm
\b
(단어 경계) : /\bHa/gm
(Ha / Harry / Hamster), /Ha\b/gm
(Ha / HaHaHa)\B
(단어 경계가 아님) : /Ha\B/gm
(HaHaHa)^
(문장의 시작) : /^Ha/gm
(HaHaHa)$
(문장의 끝) : /Ha$/gm
(HaHaHa).
(줄바꿈 문자를 제외한 모든 문자) : /./gm
\
(특수문자가 아닌 문자) : /\[\]/gm
([])\d
(숫자)\D
(숫자를 제외한 모든 것)\w
(모든 문자열 : 알파벳, 숫자, _)\W
(문자를 제외한 모든 것)\s
(띄어쓰기)\S
(띄어쓰기를 제외한 모든 것)match
(매치된 문자열을 배열로 반환, 매치가 안되면 null을 반환)replace
(매치된 문자열을 지정한 문자열로 치환)search
(매치된 문자열의 인덱스 반환, 매치가 안되면 -1을 반환 )split
(매치된 문자로 문자열을 분할하여 배열로 반환)exec
(매치된 문자열 하나를 배열로 반환, 매치가 안되면 null을 반환 )test
(매치되면 true, 안되면 false 반환 )let regExp = /^[0-9a-zA-Z]([-_\.]?[0-9a-zA-Z])*@[0-9a-zA-Z]([-_\.]?[0-9a-zA-Z])*\.[a-zA-Z]{2,3}$/i;
if(input.value.match(regExp) !== null){
매치가 되었을경우 (즉 이메일 양식이 맞춰졌을경우)
}else{
매치가 안되었을경우
};
// 8자~16자, 숫자/영어대소문자/특수문자를 모두 포함
let regExp = /^(?=.*?[a-zA-Z])(?=.*?[0-9])(?=.*?[#?!@$%^&*-]).{8,16}$/;
let price = 10000000;
let regExp = /\B(?=(\d{3})+(?!\d))/g
price.toString().replace(regExp, ",");