JSX(JavaScript XML)는 React에서 사용되는 JavaScript의 확장 문법입니다. JSX는 React에서 UI를 작성하기 위한 강력하고 편리한 방법을 제공합니다. JSX는 XML과 비슷한 문법을 사용하여 JavaScript 코드 안에 마크업을 작성할 수 있게 해줍니다.
JSX의 주요 특징과 사용법은 다음과 같습니다:
- XML과 유사한 문법: JSX는 HTML/XML과 유사한 문법을 가지고 있어, React 컴포넌트를 정의할 때 마크업을 사용하기 쉽습니다.
<person>
<name>John Doe</name>
<age>30</age>
<city>New York</city>
</person>
- JavaScript 표현식 삽입: JSX 내에서는 중괄호
{}
를 사용하여 JavaScript 표현식을 삽입할 수 있습니다.
const name = "John";
const element = <p>Hello, {name}!</p>;
- JSX는 객체로 변환: JSX 코드는 React.createElement 함수로 변환되어 React 엘리먼트 객체로 만들어집니다.
const element = <h1>Hello, World!</h1>;
// 위 코드는 아래와 같이 변환됨
const element = React.createElement('h1', null, 'Hello, World!');
- React 컴포넌트에서 사용: JSX는 React 컴포넌트의 렌더 함수에서 반환되는 요소로 사용됩니다.
class MyComponent extends React.Component {
render() {
return (
<div>
<h1>Hello, {this.props.name}!</h1>
</div>
);
}
}
- 속성 전달: JSX에서는 HTML과 같이 속성을 엘리먼트에 전달할 수 있습니다.
const element = <img src="image.jpg" alt="An example image" />;
JSX는 React 코드를 더 직관적이고 가독성 있게 만들어주며, JavaScript와의 통합을 자연스럽게 해줍니다. 하지만 JSX는 브라우저에서 직접 실행할 수 없고, 트랜스파일러를 통해 일반 JavaScript로 변환되어야 합니다.
JSX에서 주의사항은 다음과 같습니다:
- 단일 루트 엘리먼트 사용: JSX에서는 하나의 루트 엘리먼트만 반환해야 합니다. 여러 엘리먼트를 반환하려면 이들을 하나의 컨테이너 엘리먼트로 감싸야 합니다.
- 속성명은 CamelCase 사용: JSX에서는 HTML 속성 이름을 사용할 때 CamelCase를 사용해야 합니다. (예:
className
,htmlFor
)
React Fragment는 JSX에서 여러 요소를 그룹화하기 위해 사용되는 빈 문법입니다. 기존에는 여러 요소를 하나의 부모 요소로 감싸는데 div 등의 태그를 사용해야 했지만, React Fragment를 사용하면 불필요한 DOM 요소 없이 여러 요소를 그룹화할 수 있습니다.
React Fragment는 <></> 구문이나 React.Fragment라는 컴포넌트를 통해 사용할 수 있습니다.
import React from 'react';
const MyComponent = () => {
return (
<React.Fragment>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</React.Fragment>
);
};
<></> 구문은 React 16.2 버전 이후에 도입된 단축 구문으로, 불필요한 렌더링 성능 최적화에 도움이 됩니다.
import React from 'react';
const MyComponent = () => {
return (
<>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</>
);
};
React Fragment도 리스트의 각 요소에 고유한 key 속성을 부여할 수 있습니다.
import React from 'react';
const ItemList = ({ items }) => {
return (
<>
{items.map((item) => (
<React.Fragment key={item.id}>
<p>{item.name}</p>
<p>{item.description}</p>
</React.Fragment>
))}
</>
);
};
이 예제에서는 리스트의 각 항목을 React.Fragment로 그룹화하고 각 항목에는 고유한 key 속성을 부여합니다.