Vue子组件向父组件传值(this.$emit()方法)

子组件使用this.$emit()向父组件传值
首先必须在父组件中引用子组件,然后实现传值

第一步 在父组件中引入子组件

  1. 使用import引入组件
import indexImportOrder from './components/indexImportOrder'

 

  1. 声明
//定义组件
      components:{
        indexImportOrder,
      },

 

  1. 使用
<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" v-on:closeMain="closeMain"/>


val及为子组件中flag,即接收的子组件参数

closeMain(val){
        this.flag = val;
      },

项目应用:

点击选择按钮弹出module框,如图:

在模态框选择一个列表,确定后将值传入父页面。

主要代码实现:

父页面:

<rlzy-hmc-gwxsdzb-modal ref="modalGwxsdzbForm" @ok="modalFormCxOk"></rlzy-hmc-gwxsdzb-modal>


<a-form-item label="工资系数" :labelCol="labelCol" :wrapperCol="wrapperCol">
                <a-input-search v-decorator="['gwxs', validatorRules.gwxs]" placeholder="请选择工资系数"  enter-button="选择"  size="default" @search="onSearch" />
              </a-form-item>

modalFormCxOk(data) {
        this.model.gwxs = data.gwxs;
        this.$nextTick(() => {
          this.form.setFieldsValue(pick(this.model, 'gwxs'))
        })
},
onSearch(){
        this.$refs.modalGwxsdzbForm.visible=true;
      }

子页面主要代码:

<j-modal
    :title="title"
    width="100%"
    :visible="visible"
    :maskClosable="false"
    switchFullscreen
    destroyOnClose
    @ok="handleOk"
    :okButtonProps="{ class:{'jee-hidden': disableSubmit} }"
    @cancel="handleCancel">


handleOk(){
        var data={};
        if (this.selectedRowKeys.length <= 0) {
          this.$message.warning('请选择一条记录!');
          return;
        }else{
          for (var a = 0; a < this.selectedRowKeys.length; a++) {
              data= this.selectionRows[a];
          }
          this.$emit("ok",data);
          this.onClearSelected();
          this.visible = false;
        }
      },

 

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
this.$emitVue.js中用于触发自定义事件并传递数据给父组件方法。在组件中使用this.$emit可以触发父级组件中定义的$emit注册的事件,并传递组件中的参数。例如,在组件方法中使用this.$emit("delete",this.index)可以触发父组件中定义的"delete"事件,并将this.index作为参数传递给父组件。 在另一个例中,组件中的sendData方法使用this.$emit("myevent", this.childData)触发父组件中定义的"myevent"事件,并将this.childData作为参数传递给父组件组件通过this.$emit向父组件传递值的具体使用方法是在组件中使用this.$emit("function", param),其中function是父组件中定义的函数,param是需要传递给父组件的参数。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Vue入门:: this.$emit:Vue组件传值(父之间的通信)和splice()方法的用法](https://blog.csdn.net/godot06/article/details/107960472)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [【Vue】学习笔记-组件传值](https://blog.csdn.net/weixin_49202767/article/details/123142041)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Vue组件向父组件传值(this.$emit()方法)](https://blog.csdn.net/weixin_39390837/article/details/117471942)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值