Vue子组件向父组件传值(this.$emit()方法)
首先必须在父组件中引用子组件,然后实现传值
- 在父组件中引入子组件
import indexImportOrder from './components/indexImportOrder'
声明
//定义组件
components:{
indexImportOrder,
},
使用
<indexImportOrder ref="indexImportOrder"/>
- 子组件向父组件传值
(1)在子组件中需要向父组件传值处使用this.$emit(“function”,param); //其中function为父组件定义函数,param为需要传递参数
//新订单页面跳转
viewBusiness(){
let flag = false;
this.$emit('closeMain',flag);
},
(2)在父组件中子组件引用处添加函数v-on:function=“function1”; //其中function为子组件中定义函数,function1为父组件定义函数–用于接收子组件传值并进行相应数据处理,可定义为同一名称
v-on: 可用 @ 代替 @function=“function1” ,@ 为 v-on:的简写
<indexImportOrder ref="indexImportOrder" @closeMain="val"/>
val及为子组件中flag,即接收的子组件参数
val(val){
this.flag = val;
},
注意: 尽量不要让子组件emit传的参数closeMain
和和父组件中引用的方法val
相同,我设置的相同,但是没有获取到值
参考链接:
(1)https://blog.csdn.net/sisi_chen/article/details/81635216