vue3中defineEmits的使用举例详解

 更新时间:2023年08月14日 10:42:55   作者:coderXiao~  
这篇文章主要给大家介绍了关于vue3中defineEmits使用的相关资料,在Vue3中可以使用defineEmits函数来定义组件的自定义事件,文中通过代码介绍的非常详细,需要的朋友可以参考下

vue3 defineEmits的使用

以下代码和内容的使用都是在vue3的setup中,未使用TS。

1、计数器案例

父组件:

<template>
     <h2>当前计数为: {{counter}}</h2>
     <HelloWorld @add1="add1" @decre1="decre1"></HelloWorld>
</template>
<script setup>
  import { ref } from 'vue'
  import HelloWorld from './HelloWorld.vue'
  // 1、定义的属性
  const counter = ref(0)
  // 2、定义的方法
   const add1 = (payload) => {
     counter.value = payload
  }
  const decre1 = (payload) => {
     counter.value = payload
  }
</script>

子组件:

<template>
    <div>
        <button @click="increment">+1</button>
        <button @click="decrement">-1</button>
        <div>
             <input type="text" v-model.number="num">
        </div>
    </div>
</template>
<script setup>
    import { ref, defineEmits } from 'vue'
    // 1、定义的属性
    const num = ref(0)
    // 2、定义发射给父组件的方法
    const emits = defineEmits(['add1', 'decre1'])
    // 3、定义新增和递减计数方法
    const increment = () => {
        num.value++
        emits('add1', num.value)
    }
    const decrement = () => {
        num.value--
        emits('decre1', num.value)
    }
</script>

页面渲染效果

2、案例说明

1、在父组件中定义一个变量2、在子组件中定义+1和-1方法,以及一个变量3、通过子组件事件修改变量值,同时将值传递给父组件,对父组件的变量进行赋值

3、defineEmits API 使用说明

1、在子组件中调用defineEmits并定义要发射给父组件的方法

const emits = defineEmits(['add1', 'decre1'])

2、使用defineEmits会返回一个方法,使用一个变量emits(变量名随意)去接收

3、在子组件要触发的方法中,调用emits并传入发射给父组件的方法以及参数

 emits('add1', num.value)

补充知识:Vue 2中

在Vue 2中,我们可以使用$emit方法来触发自定义事件,并在父组件中通过v-on或@来监听这些事件。以下是使用Vue 2创建自定义事件的示例:

首先,在子组件中使用$emit触发自定义事件:

Vue.component('my-component', {
  methods: {
    handleClick() {
      this.$emit('my-event', 'event payload');
    }
  }
});

然后,在父组件中使用v-on或@来监听自定义事件:

<my-component v-on:my-event="handleEvent"></my-component>
<!-- 或者使用 @ -->
<my-component @my-event="handleEvent"></my-component>

最后,在父组件的方法中处理自定义事件:

methods: {
  handleEvent(payload) {
    // 处理事件逻辑
    console.log('Received event:', payload);
  }
}

在这个示例中,子组件通过$emit方法触发了一个名为my-event的自定义事件,并传递了一个payload作为参数。父组件通过v-on或@监听这个自定义事件,并在对应的方法中处理事件逻辑。

需要注意的是,在Vue 2中,自定义事件的传递是单向的,只能从子组件向父组件传递数据。如果需要在父组件中向子组件传递数据,可以使用props来实现。

使用场景:

  • 父子组件通信:自定义事件是Vue 2中实现父子组件通信的一种方式。父组件可以监听子组件触发的自定义事件,从而获取子组件传递的数据或执行相应的逻辑。
  • 组件解耦:通过使用自定义事件,可以将组件解耦,使得组件之间的通信更加灵活和可维护。组件可以通过触发自定义事件来通知其他组件发生了某些特定的动作或状态变化。

优点:

  • 灵活性:自定义事件提供了一种灵活的方式来实现组件之间的通信,可以根据具体的需求定义和触发不同的事件。
  • 组件解耦:通过使用自定义事件,可以将组件解耦,使得组件之间的通信更加灵活和可维护。

缺点:

  • 单向传递:Vue 2中的自定义事件是单向传递的,只能从子组件向父组件传递数据。如果需要在父组件向子组件传递数据,需要使用props来实现。
  • 需要手动管理事件:在使用自定义事件时,需要手动定义和管理事件的名称和参数,相对于其他通信方式,需要更多的配置和代码。

总体来说,Vue 2中的自定义事件适用于父子组件之间的通信和组件解耦的场景。它提供了一种灵活的方式来实现组件之间的通信,但需要手动管理事件,并且只能实现单向传递。在一些复杂的场景中,可能需要考虑使用Vuex或其他状态管理库来管理组件之间的共享状态。

总结 

到此这篇关于vue3中defineEmits使用的文章就介绍到这了,更多相关vue3 defineEmits使用内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue-cli框架实现计时器应用

    Vue-cli框架实现计时器应用

    这篇文章主要为大家详细介绍了Vue-cli框架实现计时器应用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • Vue2.0生命周期的理解

    Vue2.0生命周期的理解

    这篇文章主要为大家介绍了Vue2.0生命周期,思考与理解“el被新创建的vm.$el替换”这句话,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • vue制作点击切换图片效果的详细思路与步骤

    vue制作点击切换图片效果的详细思路与步骤

    这篇文章主要给大家介绍了关于vue制作点击切换图片效果的详细思路与步骤,图片切换是一个很经典的Vue入门学习案例,在你学习完一些基本的v-指令后,你可以尝试去写一个简单的demo去巩固和熟悉这些指令的使用方法,需要的朋友可以参考下
    2023-11-11
  • 解决el-date-picker 宽度溢出浏览器的问题

    解决el-date-picker 宽度溢出浏览器的问题

    这篇文章主要介绍了解决如何el-date-picker 宽度溢出浏览器问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2023-07-07
  • 前端vue中文件下载的三种方式汇总

    前端vue中文件下载的三种方式汇总

    对于Vue中实现一般的下载功能很简单,下面这篇文章主要给大家介绍了关于前端vue中文件下载的三种方式,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-02-02
  • 一文解决vue2 element el-table自适应高度问题

    一文解决vue2 element el-table自适应高度问题

    在写公司后台项目的时候遇到一个需求,要求表格页面不能有滚动条,所以必须封装一个公共方法来实现表格自适应高度,本问小编给大家介绍了如何解决vue2 element el-table自适应高度问题,需要的朋友可以参考下
    2023-11-11
  • vue组件挂载到全局方法的示例代码

    vue组件挂载到全局方法的示例代码

    这篇文章主要介绍了vue组件挂载到全局方法的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-08-08
  • el-tree树组件懒加载(后端上千条数据前端进行处理)

    el-tree树组件懒加载(后端上千条数据前端进行处理)

    本文主要介绍了el-tree树组件懒加载(后端上千条数据前端进行处理),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-03-03
  • Vue 关闭当前页、关闭当前标签tagsView的实现方法

    Vue 关闭当前页、关闭当前标签tagsView的实现方法

    这篇文章主要介绍了Vue 关闭当前页、关闭当前标签tagsView,主要有两种方式,一种是在vue页面直接实现,另一种在js文件中写自定义函数,在vue页面中调用,本文通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-08-08
  • vue项目优雅实现自动引入组件的方法详解

    vue项目优雅实现自动引入组件的方法详解

    在我们写vue项目的时候,都会引入一些组件库,有时候有可能还不止一个组件库,那么如何优雅的实现自动引入组件呢,下面小编就来和大家详细讲讲吧
    2023-09-09

最新评论