RegExp.prototype.source
        
        
          
                Baseline
                
                  Widely available
                
                
              
        
        
        
          
                
              
                
              
                
              
        
        
      
      This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015년 7월.
RegExp 인스턴스의 source 접근자 속성은 양쪽 슬래시 2개나 플래그 없이 이 정규 표현식의 소스 텍스트가 포함된 문자열을 반환합니다.
시도해 보기
const regex1 = /fooBar/gi;
console.log(regex1.source);
// Expected output: "fooBar"
console.log(new RegExp().source);
// Expected output: "(?:)"
console.log(new RegExp("\n").source === "\\n");
// Expected output: true (starting with ES5)
// Due to escaping
설명
개념적으로 source 속성은 정규식 리터럴의 두 슬래시 사이의 텍스트입니다. 이 언어는 반환된 문자열이 올바르게 이스케이프 되어야 하기에 source가 양쪽 끝에 슬래시로 연결될 때 구문 분석 가능한 정규식 리터럴이 형성됩니다. 예를 들어, new RegExp("/")의 경우 source가 /를 생성하면 결과 리터럴이 줄 주석인 //가 되기 때문에 \\/가 됩니다. 마찬가지로 모든 줄 종결자는 이스케이프 처리됩니다. 줄 종결자 문자는 정규 표현식 리터럴을 분리하기 때문입니다. 결과가 파싱 가능하기만 하다면 다른 문자에 대한 요구 사항은 없습니다. 빈 정규 표현식의 경우 문자열 (?:)이 반환됩니다.
예제
>source 사용하기
js
const regex = /fooBar/gi;
console.log(regex.source); // "fooBar", /.../ 과 "gi" 가 포함되지 않음.
빈 정규 표현식과 이스케이핑
js
new RegExp().source; // "(?:)"
new RegExp("\n").source === "\\n"; // true, ES5부터 시작됨
명새서
| Specification | 
|---|
| ECMAScript® 2026 Language Specification> # sec-get-regexp.prototype.source> | 
브라우저 호환성
Loading…