상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - Vue.js에서 v-model 디렉티브는 어떻게 작동하나요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
Vue.js에서 `v-model` 디렉티브는 양방향 데이터 바인딩을 구현하는 데 사용되는 매우 유용한 기능입니다. 이 디렉티브는 주로 폼 요소와 함께 사용되며, 사용자가 입력한 값과 Vue 인스턴스의 데이터 속성을 자동으로 동기화합니다. 이를 통해 개발자는 사용자 입력을 쉽게 처리하고, UI와 데이터 상태를 일관되게 유지할 수 있습니다. 기본 사용법 `v-model`은 HTML 폼 요소에 적용할 수 있으며, 가장 일반적으로 `<input>`, `<textarea>`, `<select>`와 함께 사용됩니다. 기본적인 사용 예시는 다음과 같습니다: ```html <div id="app"> <input v-model="message" placeholder="Type something..."> <p>{{ message }}</p> </div> <script> new Vue({ el: ' app', data: { message: '' } }); </script> ``` 위의 예제에서 사용자가 `<input>` 필드에 입력하는 내용은 `message` 데이터 속성과 자동으로 동기화됩니다. 사용자가 입력할 때마다 `message`의 값이 업데이트되고, 이는 `<p>` 태그에 실시간으로 반영됩니다. 양방향 데이터 바인딩 `v-model`의 가장 큰 장점은 양방향 데이터 바인딩입니다. 즉, 데이터 속성의 값이 변경되면 해당 값이 바인딩된 UI 요소도 자동으로 업데이트됩니다. 반대로, UI 요소의 값이 변경되면 데이터 속성도 자동으로 업데이트됩니다. 이로 인해 개발자는 데이터와 UI 상태를 일관되게 유지할 수 있습니다. 다양한 입력 유형 지원 `v-model`은 다양한 입력 유형을 지원합니다: 1. 텍스트 입력 : `<input type="text">`, `<textarea>` 등에서 사용됩니다. 2. <a href='https://sangseek.com/sangseeks/체크박스/ko'>체크박스</a> : 체크박스의 경우, `v-model`은 bo<a href='https://sangseek.com/sangseeks/olean/ko'>olean</a> 값을 바인딩합니다. ```html <input type="checkbox" v-model="checked"> Check me ``` 3. 라디오 버튼 : 라디오 버튼 그룹에서 선택된 값을 바인딩할 수 있습니다. ```html <input type="radio" v-model="picked" value="A"> A <input type="radio" v-model="picked" value="B"> B ``` 4. 셀렉트 박스 : `<select>` 요소와 함께 사용하여 선택된 값을 바인딩할 수 있습니다. ```html <select v-model="selected"> <option d<a href='https://sangseek.com/sangseeks/isabled/ko'>isabled</a> value="">Please select one</option> <option>Option 1</option> <option>Option 2</option> </select> ``` 커스텀 컴포넌트에서의 사용 Vue.js에서는 커스텀 컴포넌트에서도 `v-model`을 사용할 수 있습니다. 이 경우, 컴포넌트는 `value` prop을 통해 부모 컴포넌트의 데이터를 받고, `input` 이벤트를 통해 부모에게 변경 사항을 알립니다. 예를 들어: ```html <template> <custom-input v-model="inputValue"></custom-input> </template> <script> Vue.component('custom-input', { props: ['value'], template: `<input :value="value" @input="$emit('input', $event.target.value)">` }); </script> ``` 위의 예제에서 `custom-input` 컴포넌트는 `v-model`을 통해 부모 컴포넌트의 `inputValue`와 연결됩니다. 사용자가 입력할 때마다 `input` 이벤트가 발생하고, 부모 컴포넌트의 데이터가 업데이트됩니다. 수정자 `v-model`은 여러 가지 수정자를 지원하여 바인딩 동작을 조정할 수 있습니다. 예를 들어: - `.lazy`: 입력 이벤트 대신 `change` 이벤트에 바인딩합니다. - `.number`: 입력 값을 자동으로 숫자로 변환합니다. - `.trim`: 입력 값의 앞뒤 공백을 제거합니다. ```html <input v-model.lazy="message"> <input v-model.number="age"> <input v-model.trim="username"> ``` 결론 Vue.js의 `v-model` 디렉티브는 양방향 데이터 바인딩을 통해 사용자 입력을 쉽게 처리하고, UI와 데이터 상태를 일관되게 유지하는 데 매우 유용한 도구입니다. 다양한 입력 요소와 커스텀 컴포넌트에서 사용할 수 있으며, 수정자를 통해 바인딩 동작을 세밀하게 조정할 수 있습니다. 이러한 기능 덕분에 Vue.js는 사용자 인터페이스를 구축하는 데 있어 매우 효율적이고 직관적인 프레임워크로 자리 잡고 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기