리액트 : 프론트앤드 개발을 위한 자바스크립트 오픈소스 라이브러리.
리액트의 3가지 특징: 선언형, 컴포넌트 기반, 범용성 (다양한 곳에서 활용 가능)
DOM 과 React JSX 비교
- React에서는 DOM과 다르게 CSS, JSX 문법만을 가지고 웹 애플리케이션을 개발 가능.
- 컴포넌트 하나를 구현하기 위해서 필요한 파일이 줄어들었고, 한눈에 컴포넌트를 확인 가능.
- JSX를 사용하면 JavaScript만으로 마크업(markup) 형태의 코드를 작성하여 DOM에 배치할 수 있게 되는 것!!!
- 주의할 점은 JSX은 HTML처럼 생겼지만, HTML이 아니기 때문에 앞서 언급했던 “Babel”을 이용한 컴파일 과정이 필요
왜 JSX 써야할까?
- DOM - Javascript, HTML
- React - JSX
- DOM에서 JavaScript와 함께 사용하기 위해서는 JavaScript와 HTML을 연결하기 위한 작업이 필요. 하지만 React에서는 JSX를 이용해서 앞서 보았던 DOM 코드보다 명시적으로 코드를 작성 가능. JavaScript 문법과 HTML 문법을 동시에 이용해 기능과 구조를 한눈에 확인 가능.(한눈에 볼 수 있는 기능과 디자인)
- 컴포넌트 : 구조와 동작에 대한 코드를 한 뭉치로 적은 코드셋
- JSX 없이는 React 요소를 만들 수 없는 걸까?
: JSX 없이도 React 요소를 만들 수 있다. 다만 코드가 복잡하고, 가독성이 떨어지는 단점
주요 JSX 문법
- JSX에서 여러 엘리먼트를 작성하고자 하는 경우, opening tag와 closing tag로 감싸주기.
- React에서 CSS class 속성을 지정하려면 "className"으로 표기
: 만약 class로 작성하게 된다면 React에서는 이를 html 클래스 속성 대신 자바스크립트 클래스로 받아들이기 때문에 주의
- JSX에서 JavaScript를 쓰고자 한다면, 꼭 중괄호를 이용
: 중괄호를 사용하지 않으면 일반 텍스트로 인식
- React 엘리먼트가 JSX로 작성되면 "대문자"로 시작 : 컴포넌트
: 소문자로 시작하게 되면 일반적인 HTML 엘리먼트로 인식
이렇게 대문자로 작성된 JSX 컴포넌트를 따로 사용자 정의 '컴포넌트'라고 함.
- 조건부 렌더링은 if문이 아닌 삼항연산자를 이용
- 여러 개의 HTML 엘리먼트를 표시할 때는 "map()" 함수를 사용
: map 함수를 사용할 때는 반드시 "key" JSX 속성을 넣어야한다. key는 데이터가 가지는 고유한 id 값(식별자)을 활용. 변하지 않고, 예상 가능하며, 유일한 ID가 없으면 항목의 인덱스를 key로 사용. 인덱스를 활용은 최후의 수단(as a last resort).
"key" JSX 속성을 넣지 않으면 리스트의 각 항목에 key를 넣어야 한다는 경고가 표시 됨.
- key 속성 값이 반드시 id가 되어야 하나요? id가 존재하지 않으면 어떻게 해야 하나요?
: 리액트 공식문서 참고
: Math.random() 등으로 무작위로 생성된 값을 key로 지정하게 되면, 컴포넌트 인스턴스와 DOM 노드를 불필요하게 재생성하여 성능이 나빠질 수 있습니다. 더 자세한 내용에 대해서는 (공식문서)를 참고.
const posts = [
{ id: 1, title: "Hello World", content: "Welcome to learning React" },
{ id: 2, title: "Installation", content: "You can install React from npm" }
];
export default function App() {
// ["Hello World", "Installation"];
// TODO : JSX 활용 슬라이드를 참고해서, 에러를 해결하고 여러 개의 엘리먼트를 표시해보세요.
// 1. 한 포스트의 정보를 담은 객체가 있습니다.
// 2. 이 객체를 JSX 표현식으로 바꿔줍니다.
const postToJSX = posts.map((obj) =>
<div key={obj.id}>
<h3>{obj.title}</h3>
<p>{obj.content}</p>
</div>
);
// 포스트를 JSX로 변경해주는 함수
// 3. 포스트를 JSX로 변경하여 리턴합니다.
return (
<div className="App">
<h1>Hello JSX</h1>
{postToJSX}
</div>
);
}
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 postMsg = posts.map((el) => (
<div key={el.id}>
<h3>{el.title}</h3>
<p>{el.content}</p>
</div>
));
return (
<div>
{postMsg}
</div>
);
}


const Hello = () => {
return (
[<div>안녕하세요</div>,<div>반갑습니다.</div>]
)
}
let langs = ["JavaScript", "HTML", "Python"];
let viewLangs = () => {
return langs.map((it) => {
return <p>{it}</p>;
});
};
return (
<div>
{viewLangs}
</div>
);
: viewLangs 가 화살표 함수 표현식으로 선언되어있기 때문에 함수를 호출하는 연산자 () 를 써야 작동합니다. {viewLangs()}