🤵 JSX는 순수 자바스크립트 문법이 아닙니다. 그런데 어떻게 브라우저 상에서 동작이 가능할까요?
👩 ...
JSX란?
JSX는 JavaScript를 확장한 문법으로, 순수 자바스크립트 문법이 아니다. React에서 컴포넌트의 UI가 어떻게 생겨야 할 지를 나타내기 위해 사용되는 문법으로, 마크업과 로직이 합쳐진 형태를 하고 있다.
1const name = "ooo";2const element = <div>Hello! {name}</div>; // 이것이 JSX
위의 코드처럼 마크업 속에 중괄호를 통해 JavaScript 표현식을 넣을 수 있다. JSX 문법 또한 표현식으로 인식되며, 그 값은 자바스크립트 객체이다.
JSX가 마크업을 사용하기는 하지만 자바스크립트 내에서 사용되고, 따라서 자바스크립트와 가깝다고 보기 때문에, HTML 마크업에서의 요소들과는 차이가 있다. 예를 들어 class
어트리뷰트는 className
이 된다.
JSX는 XSS 공격을 방지하기 위해서 삽입된 모든 값을 렌더링 전에 이스케이프한다. 단, 문자열 리터럴은 HTML 이스케이프 처리가 되지 않는다.
Babel은 자바스크립트 트랜스컴파일러로, 작성된 자바스크립트 코드가 다른 버전의 자바스크립트 버전과 호환되도록 자바스크립트 문법을 변환해준다. JSX는 Babel을 거쳐서 React Element 객체를 생성하는 문으로 컴파일된다. 그러면 React는 React Element 객체를 읽어서 DOM을 구성하고, 최신 상태로 유지하는 데 사용한다. 그래서 React 공식 문서에서는 JSX를 React.createElement(...)
함수의 문법적 설탕이라고 설명한다.
- 이렇게 작성된 JSX 코드가 있다면,
1const element = <div className="hi">Hello World</div>;2ReactDOM.render(element, document.getElementById('root'));
- 바벨을 거치면 이런 식으로 컴파일된다.
1const element = React.createElement(2 "div",3 {className: "hi"},4 "Hello World"5);6ReactDOM.render(element, document.getElementById('root'));
- 결과적으로 이렇게 렌더링된다.
1<div id="root">2 <div>Hello World</div>3</div>
바벨 컴파일은 여기에서 테스트해 볼 수 있다.