[공지사항] 푸샤 깃허브 블로그 업데이트 사항

checked & defaultChecked

기본 엘리먼트에서는 checked 속성으로 사용하지만 react 에서는 defaultChecked값이 추가되었습니다. 이 두 가지 속성은 역할은 같지만 작은 차이가 있습니다.

// radio
<input
	type="radio"
	name="name"
	id="id"
	value="value"
	label="label"
	defaultChecked={true}/>

    // checkbox
<input
	type="checkbox"
	name="name"
	id="id"
	value="value"
	label="label"
	defaultChecked={true}/>

checked

checked값을 사용하면 onChange값과 함께 사용하여 컨트롤할 수 있습니다. 만약 onChange 값이 없으면 해당 컴포넌트는 readOnly로 바뀌어 체크를 변경할 수 없습니다.

<input
	type="checkbox"
	name="foo"
	value="bar"
	onChange={(e) => this.setState({ foo: !this.state.foo })}
	checked={this.state.foo}/>

<p>checked: {this.state.foo ? 'true' : 'false'}</p>

defaultChecked

onChange값과 관계없이 checked 값을 변경할 수 있습니다. 폼을 state로 관리하지 않는다면 defaultChecked 값을 사용하는것을 권장합니다.

checked vs defaultChecked

두개의 값은 같은 성격을 가지고 있기 때문에 한번에 사용할 수 없습니다. 두개의 값이 다 있거나 없으면 defaultChecked 값이 우선적으로 사용됨을 주의해주세요.

요약

  • 만약 onChange 사용하면 checked를 권장하고, state를 onChange로 관리하지않으면 defaultChecked 사용해본다
  • radio나 check 사용시 에러가 뜬다면 현재 사용하고 있는 값을 checked 혹은 defaultChecked를 변경해보자. 필자의 경우 onChange 변경 값(체크 적용)이 제대로 먹히지 않아 한참 디버깅하다가 defaultChecked를 Checked로 변경하니 간단하게 문제해결되었다. (하단 이미지 참조)

참조 문서 및 사이트

상단으로 푸샤 깃허브 이동

댓글남기기