vue基础--通过$emit 实现组件间通信

通过$emit 实现子组件向父组件通信

官网定义:vm.$emit( event, arg )

解释:子组件中通过$emit 绑定一个自定义事件event(formSubmit1),当这个这个语句被执行到的时候,就会将参数arg(textToTranslate)传递给父组件,父组件通过@event(@formSubmit1)监听并接收参数(textToTranslate)

父组件:App.vue

<template>
  <div id="app">
    <TranslateForm @formSubmit1="translateText"></TranslateForm>
  </div>
</template>

<script>

import TranslateForm from './components/TranslateForm.vue'
export default {
  name: 'App',
  components: {
    TranslateForm
  },
  methods:{
    translateText:function (text) {
      alert(text);
    }
  }
}
</script>

子组件:TranslateForm.vue

<template>
    <div>
      <form @submit="formSubmit">
        <input type="text" v-model="textToTranslate" placeholder="请输入">
        <select>
          <option value="en">English</option>
        </select>
        <input type="submit" value="翻译">
      </form>
    </div>
</template>
<script>
    export default {
      data:function(){
        return {
          textToTranslate:""
        }
      },
      methods:{
        formSubmit:function (e) {
          this.$emit("formSubmit1",this.textToTranslate);
          e.preventDefault();
        }
      }
    }
</script>
转自:https://www.jb51.net/article/140581.htm中的第3个

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值