Vue自定义事件

父组件使用props传递数据给子组件,子组件怎么跟父组件通信呢?这时,Vue的自定义事件就派上用场了。

1、自定义事件

每个Vue创建的实例都会出现一个事件接口

 var vm = new Vue({
    el: '#app'
  })
  • 自定义事件的定义(发布)
 //vm.$on(自定义事件的名称,自定义事件的事件处理程序)
 vm.$on( 'aa', function () {
    console.log( 'aa' )
  })
  
  • //自定义事件的触发 ( 订阅 )
 // vm.$emit( 自定义事件的名称,自定义事件处理程序需要的参数1,参数2,参数3)

    vm.$emit( 'aa' )

2、自定义事件的数据传递

我们通过下面代码分析一下自定义事件的数据传递

<body>
   <div id="app">
      <Father></Father>
   </div>

   <template id="father">
      <div>
         <h3>这里是父组件</h3>
         <p>儿子给我{{ money}} </p>
         <Son @hongbao="givemoney"></Son>
      </div>

   </template>

   <template id="son">
      <div>
         <h3>这里是子组件</h3>
         <button @click="give">给父亲红包</button>
      </div>
   </template>
</body>

<script>
   Vue.component('Father',{
      template:'#father',
      data(){
         return {
            money:0,
         }
      },
      methods:{
          //自定义事件的定义(发布)
         givemoney(val){
            this.money=val;
         }
      }

   });

   Vue.component('Son',{
      template:'#son',
      data(){
        return {
           money:3000,
        }
      },
      methods:{
         //自定义事件的触发 ( 订阅 )
         give(){
            console.log(this.money)
            this.$emit('hongbao',this.money)
         }
      }
   })

   new Vue({

   }).$mount('#app')

从上述代码可以看出,父组件通过$on监听事件,事件处理函数的参数则为接收的数据

 methods:{
          //自定义事件的定义(发布)
         givemoney(val){
            this.money=val;
         }
      }

子组件通过$emit可以触发事件,第一个参数为要触发的事件,第二个事件为要传递的数据

  methods:{
         //自定义事件的触发 ( 订阅 )
         give(){
            console.log(this.money)
            this.$emit('hongbao',this.money)
         }
      }
  • 14
    点赞
  • 53
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
Vue 自定义事件可以用于在组件之间传递数据。通过在父组件中使用`$emit`方法触发自定义事件,并在子组件中使用`$on`方法监听该事件,可以实现子组件向父组件传递数据。 在Vue中,可以使用`emits`选项来声明组件支持的自定义事件。在子组件中,使用`this.$emit(eventName, data)`方法触发自定义事件,并传递数据data。父组件可以通过监听这个自定义事件来接收子组件传递的数据。 另外,还可以通过在子组件中使用`v-on`或`@`语法来绑定父组件的自定义事件,从而实现子组件向父组件传递数据。在子组件中触发自定义事件后,父组件可以通过事件处理函数来接收传递的数据。 综上所述,Vue 自定义事件是一种很方便的方式来传递数据和实现组件之间的通信。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Vue自定义事件(详解)](https://download.csdn.net/download/weixin_38641339/13624910)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [Vue自定义事件](https://blog.csdn.net/qq_48731430/article/details/121779200)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [Vue 自定义事件实现子组件数据向父组件传输](https://blog.csdn.net/weixin_41987908/article/details/127498540)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值