
정규식은 아무리봐도 내가 작성하기가 너무 힘들어,,
라는 생각으로 정리하게 되었답니다~
정규표현식이란?
- 정규 표현식, 또는 정규식은 문자열에서 특정 문자 조합을 찾기 위한 패턴입니다.
- 장점으로는 문자열 처리에 최적
- 단점으로는 가독성이 떨어짐
이메일, 비밀번호, 아이디, 닉네임, 숫자 콤마 등등 정규식은 대체로 많이 이용하게 되는데요
프론트엔드라면 이에 해당하는 정규식, 더 나아가서 유효성 검사까지 구현해낼줄 알아야해요
// 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, ",");