Header 컴포넌트에 div 말고 애초에 button은 안 되나요?
궁금한 점이 2가지 있는데요
1. Header 컴포넌트에 div 말고 애초에 button를 넣으면 안 되나요?
Header.jsx
const Header = ({ title, leftChild, rightChild }) => {
return (
<header className="Header">
<button className="header_left">{leftChild}</button>
<div className="header_center">{title}</div>
<button className="header_right">{rightChild}</button>
</header>
);
};App.jsx
<Header title={"Header"} leftChild={"Left"} rightChild={"Right"} />이런 식으로 헤더 컴포에 처음부터 버튼 태그를 넣으면 될 것 같은데 왜 div로 감싸는 건가요?
음.. 그냥 css 편의상 이유일까요?
2. 저는 css를 배울 때 처음에 charset "utf-8"; 을 항상 입력하라고 배웠는데 리액트 강의에서는 항상 안 사용하시더라구요. 리액트에서는 원래 안 쓰는건가요, 아니면 그냥 강의에서는 굳이 필요없어서 쓰지 않는건가요?
답변 1
0
안녕하세요 이정환입니다.
1) 물론 말씀하신대로 Header 컴포넌트 내에 <button> 요소를 고정시켜 두어도 상관은 없습니다. 다만 이렇게 작업할 경우 향후 동일한 위치에 <button>이 아닌 다른 요소를 넣고 싶을때 대대적인 수정이 필요하게 됩니다. 그리고 UI 요소는 이런 변화가 다른 요소에 비해 잦습니다. 따라서 확장에 유연하게 설계하기 위해 이렇게 구현하고 있습니다.
2) 좋은 질문이네요! charset "utf-8"; 은 한글 문자 등의 문자 인코딩을 명시하기 위해 사용되는 문법인데 리액트 프로젝트에는 보통 index.html 파일의 <head> 태그 안에 <meta charset="UTF-8">이 이미 포함되어 있습니다. 따라서 굳이 중복으로 정의할 필요가 없어 생략합니다.
useEffect와 lifecycle문의
0
16
1
프론트엔드 학습 수준 문의
0
27
2
리액트 챕터별 코드에서 eslint 설정파일이 없어요
0
42
2
데이터 로딩중 화면만 계속 나와요!!
0
51
2
퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요
0
76
2
이후의 커리큘럼 문의
0
101
2
실슬환경 설정에서 save후 console.log 부분이 새로고침이 안되는현상입니다.
0
49
2
최적화 관련 질문있습니다 (useMemo 등)
0
82
3
프로바이더 컴포넌트의 위치는 어떤 기준인가요?
1
79
3
Date 객체에 관련하여 질문드립니다.
0
82
2
리액트 개정판 교재 질문
0
58
2
예제코드가 안나와요!
0
75
2
select a variant 선택에서 javascript와 javascript+react compiler 중 무엇을 선택해야하나요? com
0
104
2
onMouseEnter 관련 문의 드립니다
0
89
3
배열의 렌더링 관련 질문 드립니다.
0
70
2
2:40초 refObj를 콘솔로 출력시 오류가 발생합니다.
0
111
2
TS, 리액트 강의중에 뭘 먼저 수강하는게 좋을까요?
0
131
2
useCallback 적용한 onCreate, onUpdate, onDelete 함수..
0
66
1
vs code 자동완성관련 문의
0
107
2
91강 useEffect내에서 상태변화함수 호출시 발생하는 에러
1
174
2
87강 필터 함수 질문
0
65
2
useRef, useState count 비교
0
64
2
안된다고했던 이유가 무엇이었는지 모르겠습니다
0
86
2
85강에서 객체를 왜 클래스로 만들어서 new 하지 않는건지 궁금합니다.
0
73
2





