Vue.js는 단방향 데이터 바인딩과 함께 양방향 데이터 바인딩을 지원하는 JavaScript 프레임워크입니다. 양방향 데이터 바인딩을 사용하면 데이터의 변경이 화면에 실시간으로 반영되어 사용자 경험을 향상시킬 수 있습니다.
Vue.js에서 양방향 데이터 바인딩을 구현하는 방법을 알아보겠습니다.
1. v-model 디렉티브를 사용한 양방향 데이터 바인딩
Vue.js에서 v-model 디렉티브를 사용하면 폼 요소의 값과 데이터를 양방향으로 바인딩할 수 있습니다. 예를 들어, input 요소에 v-model 디렉티브를 적용하면 사용자가 입력한 값과 데이터가 실시간으로 동기화됩니다.
<template>
<div>
<input type="text" v-model="message">
<p>{{ message }}</p>
</div>
</template>
<script>
export default {
data() {
return {
message: ''
}
}
}
</script>
위의 코드에서 input
요소에 v-model="message"
를 사용하면 사용자가 입력한 값이 message
데이터에 자동으로 업데이트되며, p
요소에서는 message
데이터를 보여줍니다.
2. computed 속성을 사용한 동적 데이터 업데이트
Vue.js에서 computed 속성은 데이터 값에 기반하여 자동으로 계산된 값을 반환하는 속성입니다. 이를 활용하여 데이터 값이 변경될 때마다 실시간으로 업데이트된 값을 사용할 수 있습니다.
<template>
<div>
<input type="number" v-model="quantity">
<p>총 가격: {{ totalPrice }}</p>
</div>
</template>
<script>
export default {
data() {
return {
quantity: 0,
price: 10
}
},
computed: {
totalPrice() {
return this.quantity * this.price;
}
}
}
</script>
위의 코드에서 quantity
데이터와 price
데이터를 곱하여 totalPrice
데이터를 계산하고, 이를 화면에 보여줍니다. 사용자가 quantity
값을 입력할 때마다 totalPrice
가 자동으로 업데이트됩니다.
결론
Vue.js의 양방향 데이터 바인딩을 이용하면 사용자와의 상호작용에 따라 데이터를 실시간으로 업데이트할 수 있으므로 보다 동적이고 편리한 웹 애플리케이션을 개발할 수 있습니다. v-model 디렉티브와 computed 속성을 적절히 활용하여 데이터 바인딩을 구현하면 됩니다.
#Vue.js #양방향데이터바인딩