vue組件有2大特性:
1.全局組件和局部組件
2.父子組件的數據傳遞
接下來直接用demo直接看如何傳值(靜態傳值)
father.vue
<template>
<div>
<Counter num="10"></Counter>//靜態傳值
</div>
</template>
<script>
import Counter from './child.vue' //引入子組件
export default {
components:{Counter}, //命名子組件
data(){
}
}
</script>
child.vue
<template>
<div>
<button>+</button>
<p><span>{{num}}</span></p>
</div>
</template>
<script>
export default {
props:['num'], //props接收父組件傳來的值。num必須和父組件的命名一樣
methods:{
}
}
</script>
動態傳值
father.vue
<template>
<div>
//動態改變num值需要用v-bind,子組件通$emit變量獲取父組件的方法,接收事件名
<Counter v-bind:num="num" v-on:incre="increment" v-on:decre="decrement"></Counter>
</div>
</template>
<script>
import Counter from './child.vue'
export default {
components:{Counter},
data(){
return{
num:10,
}
},
methods:{
increment(){
this.num++;
},
decrement(){
this.num--;
}
}
}
</script>
child.vue
<template>
<div>
<button @click="increment">+</button>
<button @click="decrement">-</button>
<p><span>{{num}}</span></p>
</div>
</template>
<script>
export default {
data(){
return{}
},
props:['num'],
methods:{
increment(){
this.$emit('incre'); //獲取父組件的方法,動態獲取父組件的num值
},
decrement(){
this.$emit('decre');
}
}
}
</script>
