작성
·
1.8K
·
수정됨
1
//template
<tr v-for="(product,index)
in productList" :key="product.id">
// setup
let productList = reactive([])
const getProductList = function() {
productService.getProductList(null, null, null, null)
.then((response) => {
console.log('response.data.data :', response.data.data); // array
console.log(productList)
productList = response.data.data
console.log(productList)
})
}
이 코드에서 productList = response.data.data를 할당하니까 반응성이 사라지더라구요 ( 변수에 새로운 값을 할당해버린 게 그 원인이었구요)
그래서
1) productList = ref([]) 로 하고
productList.value = response.data.data 하니까 정상 작동
2) productList = reactive({ a : []}) 로 하고
productList.a = response.data.data
template에서
<tr v-for="(product,index)
in productList.a" :key="product.id">
로 사용하니까 정상 작동
3) 이것만 보면 ref로 선언하면 데이터를 받아올 때 .value 하나만 추가해주면 끝이지만 reactive를 사용하면 .a를 이곳저곳에 다 붙여줘야 되는데 객체, 배열은 reactive 안에 넣어서 사용하는 이유는 뭔가요?
4) 그냥 reactive는 버리고 ref로만 모든 반응형을 선언해도 기능상에 문제는 없나요?
답변 1
0
안녕하세요.
reactive
의 이점은 객체타입을 선언시 유용합니다. .value
를 붙이지 않아도 되니까요.
하지만 ref
, reactive
를 혼용해서 개인적으로 일관성 없고 불편해서 저도 ref
를 주로 사용하는 편입니다. (이러한 이유에 대해서는 강의에서 언급합니다.)
팀이나 개인의 선호에 따라 사용하시면 될 것 같아요~!