반응형
- Props
1)데이터는 한 곳에 보통 보관한다 (App.vue 같은곳) 그리고 필요하면 가져다 쓴다.
2)v-bind (축약은 :)를 이용해 이름 : "props할 데이터" 형식으로 넘겨준다.
3)props받은 컴포넌트쪽에 props등록을 해준다. 받은데이터이름 : 자료형인데 자료형은 디버깅용이라 틀려도 되지만
맞춰주도록 하자
......
<ModalPopup v-bind:oneroom="oneroom" :roomNumber="roomNumber" :modal="modal"></ModalPopup>
<!-- 혹은 v-bind는 축약 가능-->
<div class="menu">
<a v-for="(a,i) in 메뉴들" :key="i">{{ a }}</a>
</div>
<DiscountBanner></DiscountBanner>
<CardList :oneroom="oneroom"></CardList>
.......
export default {
name: 'App',
data(){
return{
modal : false, // 닫힌 상태와, 열린상태 2가지 표현 0과1로 혹은 true,false
alert:[0,0,0],
price1 : 60,
price2 : 70,
price3:80,
prices:[60,70,80],
스타일 : 'color:blue',
products: ["은평구원룸",'천호동원룸','마포구원룸'],
메뉴들 : ["Home","Shop","About"],
images:["room0.jpg","room1.jpg","room2.jpg"],
oneroom:data,
roomNumber:0,
//import 해온것
}
},
.....
export default {
name:'CardList',
props:{
oneroom:Object,
//props받은 데이터이름 : 자료형
},
- Component
App.vue 밑에 ModalPopup, DiscountBanner, CardList 라는 이름으로 만든 vue파일들을 등록했다.
1)ModalPopup, DiscountBanner, CardList 라는 이름으로 vue파일로 컴포넌트를 만든다.
2)각 파일안에 name등록을한다.
3)App.vue 에서 import해온다.
4)App.vue의 component에 등록을한뒤 사용한다.
App.vue
......
<ModalPopup v-bind:oneroom="oneroom" :roomNumber="roomNumber" :modal="modal"></ModalPopup>
<!-- 혹은 v-bind는 축약 가능-->
<div class="menu">
<a v-for="(a,i) in 메뉴들" :key="i">{{ a }}</a>
</div>
<DiscountBanner></DiscountBanner>
<CardList :oneroom="oneroom"></CardList>
......
<script>
import data from './assets/data'
import DiscountBanner from './DiscountBanner.vue'
import ModalPopup from './ModalPopup.vue'
import CardList from './CardList.vue'
// import {} from ~
........
components: {
DiscountBanner:DiscountBanner,
ModalPopup:ModalPopup,
CardList:CardList,
// 똑같으면 하나로 축약가능 DiscountBanner하나로
}
}
</script>
각 소스코드 파일 참고해보자, 참고로 props 까지는 전부 사용했지만 (부모->자식)
역으로 자식->부모로 데이터를 건드리는쪽은 건들기 전 코드이다.
반응형
'Vue.js' 카테고리의 다른 글
Vue.js input값 받기 (v-model), watcher (데이터 감시) (0) | 2023.04.01 |
---|---|
Vue.js props, custom event (자식에서 부모 데이터 수정) (0) | 2023.04.01 |
Vue.js 상세페이지(변수로 구분), 컴포넌트, v-if 추가학습 (0) | 2023.03.30 |
Vue.js 이벤트 핸들러(v-on:click), 조건문(v-if) (0) | 2023.03.29 |
Vue.js CDN으로 간단하게 전체 맛보기 (0) | 2023.03.29 |