코사장의 코딩 놀이터

웹개발

JSX에 대한 소개

코사장_ 2023. 4. 21. 22:13
반응형

1. JSX 기본 개념

JSX(JavaScript XML)는 React를 사용하여 UI 구성 요소를 생성하기 위한 JavaScript의 확장 문법입니다. JSX는 HTML과 유사한 구조를 가지지만, JavaScript 내에서 작성되므로 HTML과 JavaScript의 결합을 더 쉽게 처리할 수 있습니다.

 

React & JSX

 

2. JSX 사용법

JSX를 사용하기 위해서는 React를 먼저 설치해야 합니다. React 프로젝트를 생성하거나, 기존 프로젝트에 React를 추가하면 JSX를 사용할 수 있습니다.

JSX를 사용하여 React 컴포넌트를 작성할 때, HTML 태그 대신 JSX 요소를 사용합니다. JSX 요소는 일반적인 HTML 태그와 유사하지만, JavaScript 표현식을 사용할 수 있습니다. 예를 들어, 다음과 같이 JSX를 사용하여 간단한 React 컴포넌트를 작성할 수 있습니다.

import React from 'react';

function HelloWorld() {
  return (
    <div>
      <h1>Hello, world!</h1>
    </div>
  );
}

export default HelloWorld;

 

3. JSX 예제 코드

JSX를 사용하여 동적인 웹 페이지를 작성하는 예제를 살펴보겠습니다. 다음은 React와 JSX를 사용하여 간단한 할 일 목록을 생성하는 예제입니다.

import React, { useState } from 'react';

function TodoList() {
  const [todos, setTodos] = useState([]);
  const [inputValue, setInputValue] = useState('');

  function addTodo() {
    setTodos([...todos, inputValue]);
    setInputValue('');
  }

  return (
    <div>
      <input
        type="text"
        value={inputValue}
        onChange={(event) => setInputValue(event.target.value)}
      />
      <button onClick={addTodo}>추가</button>
      <ul>
        {todos.map((todo, index) => (
          <li key={index}>{todo}</li>
        ))}
      </ul>
    </div>
  );
}

export default TodoList;

이 예제에서는 useState 훅을 사용하여 상태를 관리하고, JSX를 사용하여 UI를 구성하였습니다. 입력한 할 일을 배열에 추가하고, JSX의 map 함수를 사용하여 배열을 순회하며 목록을 생성합니다.

 

4. JSX의 장점

  1. 가독성: JSX는 HTML과 유사한 구조를 가지고 있어서, 웹 페이지의 구조를 쉽게 파악할 수 있습니다. 이로 인해 코드의 가독성이 높아집니다.
  2. 유지보수성: JSX를 사용하면, UI 구성 요소와 관련된 JavaScript 코드를 동일한 파일 내에서 작성할 수 있습니다. 이로 인해 유지보수성이 향상됩니다.
  3. 컴포넌트 기반 개발: JSX를 사용하면, 컴포넌트 기반으로 개발할 수 있습니다. 이는 코드의 재사용성을 높이고, 개발 과정에서 생산성을 향상시킵니다.

 

5. JSX와 일반 JavaScript, HTML의 차이점

JSX는 JavaScript의 확장 문법이지만, 일반 JavaScript와 HTML과는 몇 가지 차이점이 있습니다.

  1. JavaScript 표현식 사용: JSX에서는 중괄호({})를 사용하여 JavaScript 표현식을 삽입할 수 있습니다. 이를 통해 변수, 함수 호출 등의 동적인 값을 JSX 내에서 사용할 수 있습니다.
  2. 속성 이름: JSX에서는 HTML 속성과 유사한 속성을 사용하지만, 몇 가지 차이점이 있습니다. 예를 들어, class 속성은 className으로, for 속성은 htmlFor로 사용해야 합니다.
  3. 단일 루트 요소: JSX에서는 컴포넌트의 렌더링 결과물을 하나의 루트 요소로 감싸야 합니다. 즉, 여러 개의 동일한 레벨의 요소를 반환할 수 없습니다.

 

6. JSX 사용 시 주의사항

  1. 모든 태그는 닫혀야 함: JSX에서는 모든 태그를 닫아야 합니다. 즉, 자동으로 닫히는 HTML 태그도 명시적으로 닫아야 합니다. 예를 들어, <input> 태그를 사용할 때는 <input />과 같이 닫아야 합니다.
  2. 속성 값에 따옴표 사용: JSX에서는 속성 값을 따옴표로 감싸야 합니다. 예를 들어, <div className="container">와 같이 작성해야 합니다.
  3. 주석 처리 방법: JSX에서는 JavaScript 주석을 사용할 수 있지만, 중괄호({}) 안에 주석을 작성해야 합니다. 예를 들어, {/* 이것은 JSX 주석입니다. */}와 같이 작성할 수 있습니다.

이러한 주의사항을 지키면서 JSX를 사용하면, 효과적으로 React 컴포넌트를 개발할 수 있습니다.

 

7. JSX 작성 시 도구와 확장 프로그램

JSX를 작성하면서 개발 환경을 더 편리하게 만들어주는 도구와 확장 프로그램이 있습니다. 이들 도구를 사용하면, 개발 과정에서 시간을 절약하고 생산성을 높일 수 있습니다.

  1. Prettier: Prettier는 코드 포매터로, 자동으로 코드를 정리해주어 일관된 스타일을 유지할 수 있습니다. Prettier를 사용하면, JSX 작성 시 들여쓰기, 띄어쓰기 등을 자동으로 처리해 줍니다.
  2. ESLint: ESLint는 JavaScript와 JSX 코드를 분석하여 문제점을 찾아주는 도구입니다. ESLint를 사용하면, 실수로 발생할 수 있는 오류를 미리 확인하고 수정할 수 있습니다.
  3. Visual Studio Code 확장 프로그램: Visual Studio Code에서는 여러가지 JSX 관련 확장 프로그램을 제공합니다. 예를 들어, 'Reactjs code snippets' 확장 프로그램을 사용하면, 자주 사용되는 React와 JSX 코드를 빠르게 입력할 수 있습니다.

 

8. 결론

JSX는 React에서 UI 구성 요소를 생성하기 위한 강력한 도구입니다. HTML과 유사한 구조를 가지고 있지만, JavaScript와의 결합을 더 쉽게 처리할 수 있습니다. 이 글에서는 JSX의 기본 개념, 사용법, 예제 코드, 그리고 주의사항 등에 대해 설명하였습니다. 이를 바탕으로, JSX를 활용하여 더 효율적인 React 개발을 진행해보시기 바랍니다.

 

반응형

'웹개발' 카테고리의 다른 글

Github 소개  (0) 2023.04.21
Git 이란 무엇인가?  (0) 2023.04.21
핸들바(Handlebars) 소개  (0) 2023.04.21
MUI 소개  (0) 2023.04.21
React의 State에 대한 소개  (0) 2023.04.21