React에서 자손 컴포넌트에서 상태 편집하기
이전 수업에서 얻은 Product 컴포넌트를 살펴보겠습니다:
function Product({ id, name, cost, isEdit, toggleMode, editProd }) {
return <div>
name: {
isEdit
? <input value={name} onChange={event => editProd(id, 'name', event)} />
: <span>{name}</span>
}
cost: {
isEdit
? <input value={cost} onChange={event => editProd(id, 'cost', event)} />
: <span>{cost}</span>
}
<button onClick={() => toggleMode(id)}>
{isEdit ? 'save': 'edit'}
</button>
</div>;
}
제품 이름과 제품 가격에 대한 코드가 거의 중복된다는 것을 쉽게 알 수 있습니다.
이 코드를 별도의 ProductField 컴포넌트로 추출해 보겠습니다:
function ProductField({ id, text, type, isEdit, editProd }) {
return isEdit
? <input value={text} onChange={event => editProd(id, type, event)} />
: <span>{text}</span>
;
}
Product 컴포넌트를 수정해 보겠습니다:
function Product({ id, name, cost, isEdit, toggleMode, editProd }) {
return <div>
name: <ProductField
id={id}
text={name}
type="name"
isEdit={isEdit}
editProd={editProd}
/>,
cost: <ProductField
id={id}
text={cost}
type="cost"
isEdit={isEdit}
editProd={editProd}
/>
<button onClick={() => toggleMode(id)}>
{isEdit ? 'save': 'edit'}
</button>
</div>;
}
이전 수업에서 생성한 User 컴포넌트에 대해 유사한 작업을 수행하십시오.