오늘도 삽질중

JSX규칙 본문

카테고리 없음

JSX규칙

해빋 2021. 9. 15. 12:37

JSX규칙

1.  JSX에서 여러 엘리먼트를 작성하고자 하는 경우 opening tag와 closing tag로 감싸주어야한다.

ERROR :    Adjacent JSX elements must be wrapped in an enclosing tag.

const posts = [
  { id: 1, title: "Hello World", content: "Welcome to learning React!" },
  { id: 2, title: "Installation", content: "You can install React via npm." },
  { id: 3, title: "Practice", content: "Practice React via npm run start" }
];

export default function Blog() {
  const newPosts = posts.map(el => 
    ( //<div></div>로 감싸주지 않으면 오류가 생긴다.
      // Adjacent JSX elements must be wrapped in an enclosing tag.
      // 따라서 꼭!!꼭!! <div>태그로 감싸주자
      <div>
      <h3>{el.title}</h3>
      <h4>{el.content}</h4> 
      </div>   
  )
  )

  return (
    <div>
      <div>
        <h3>{posts[0].title}</h3>
        <p>{posts[0].content}</p>
      </div>
      <div>
        {newPosts}
      </div>
    </div>
  );
}

오류
오류 해결!!!

 

 

 

2.  React에서 CSS class속성을 지정하려면 'className'으로 표기해야한다.( 만약 class를 사용하면 리액트에서 html클래스 속성대신 자바스크립트 클래스로 받아들이기 때문에 주의해야한다)

3.  JSX에서 JavaScript를 쓰고자 한다면 꼭 중괄호를 이용해야한다. 중괄호 사용 안하면 일반 텍스트로 인식을 한다.

4.  사용자 정의 컴포넌트는 대문자로 시작한다. 소문자로 시작하게되면 일반적인 HTML엘리먼트로 인식을 하게된다.  이렇게 대문자로 작성된 JSX컴포넌트를 따로 사용자 정의 컴포넌트라고 부른다.

5. 조건부 렌더링에는 if문이 아닌 삼항연산자를 이용한다.

6.  여러 개의 HTML엘리먼트를 표시할 때 map()함수를 이용한다. map함수를 사용할때는 반드시 "key" JSX속성을 넣어야 한다. "key"JSX 속성을 넣지 않으면 리스트의 각 항목에 key를 넣어야 한다는 경고가 표시된다. 

Comments