前端必知必会之Vue $emit()方法详解

 更新时间:2025年02月28日 09:00:25   作者:编程岁月  
这篇文章主要介绍了前端必知必会之Vue $emit()方法的相关资料,Vue.js中的$emit()方法用于在子组件中创建自定义事件,并在父组件中捕获这些事件,这在需要从子组件向父组件传递信息的大型项目中非常有用,需要的朋友可以参考下

Vue $emit() 方法

使用 Vue 中内置的 $emit() 方法,我们可以在子组件中创建一个自定义事件,该事件可以在父元素中捕获。

Props 用于将数据从父元素发送到子组件,而 $emit() 用于执行相反的操作:将信息从子组件传递到父组件。

我们接下来要做的事情的目的是最终在父 App.vue 中更改食品的“收藏”状态,而不是在当前发生变化的 FoodItem.vue 子组件中更改。

在 App.vue 中而不是在 FoodItem.vue 中更改收藏状态的原因是,App.vue 是收藏状态的存储位置,因此需要更新。在较大的项目中,数据可能来自我们在 App.vue 中连接的数据库,并且我们希望组件中发生的更改会在数据库中进行更改,因此我们需要从子组件向父组件进行通信。

发出自定义事件

需要将信息从组件发送到父级,我们使用内置方法 $emit() 来执行此操作。

我们在 FoodItem.vue 组件中已经有 toggleFavorite 方法,该方法在单击切换按钮时运行。现在让我们删除现有行并添加一行以发出我们的自定义事件“toggle-favorite”:

FoodItem.vue:

methods: {
  toggleFavorite() {
    //this.foodIsFavorite = !this.foodIsFavorite;
    this.$emit('toggle-Favorite');
  }
}

我们可以选择自定义事件的名称,但使用短横线命名来发出事件是正常的。

接收发射事件

自定义发射事件“toggle-favorite”现在从 FoodItem.vue 组件发射,但我们需要在 App.vue 父级中监听该事件并调用执行某些操作的方法,以便我们可以看到事件已发生。

在创建组件的 App.vue 中,我们使用简写 @ 而不是 v-on: 来监听事件:

示例获取您自己的 Vue 服务器
在 App.vue 中监听 ‘toggle-favorite’ 事件:

<food-item
v-for="x in foods"
:key="x.name"
:food-name="x.name"
:food-desc="x.desc"
:is-favorite="x.favorite"
@toggle-favorite="receiveEmit"
/>

当我们的自定义 ‘toggle-favorite’ 事件发生时,我们需要在 App.vue 中创建 acceptEmit 方法,以便我们可以看到事件发生了:

methods: {
  receiveEmit() {
    alert('Hello World!');
  }
}

在父组件中更改食物项目的“favorite”状态

我们现在有一个事件,当从子组件单击“favorite”按钮时,它会通知 App.vue。

当单击“favorite”按钮时,我们想要将 App.vue 中“foods”数组中的“favorite”属性更改为正确的食物项目。为此,我们将食物项目名称从 FoodItem.vue 发送到 App.vue,因为每个食物项目的名称都是唯一的:

FoodItem.vue:

methods: {
  toggleFavorite() {
    this.$emit('toggle-favorite', this.foodName);
  }
}

我们现在可以在 App.vue 中接收食物名称作为 ‘toggle-favorite’ 事件发生时调用的方法的参数,如下所示:

示例

App.vue:

methods: {
receiveEmit(foodId) {
alert('您点击了:'+foodId);
}
}

现在我们知道了被点击的食物,我们可以更新’foods’数组中正确食物的’favorite’状态:

App.vue:

methods: {
receiveEmit(foodId) {
const foundFood = this.foods.find(
food => food.name ===foodId
);
foundFood.favorite = !foundFood.favorite;
}
}

在上面的代码中,数组方法“find”遍历“foods”数组并查找 name 属性等于我们单击的食物项的对象,并将该对象返回为“foundFood”。之后,我们可以将“foundFood.health”设置为与之前相反的值,以便它在 true 和 false 之间切换。

“foods”数组中的正确食物现在会更新其“favorite”状态。剩下的唯一事情就是更新指示最喜欢的食物的图像。

因为食物组件已经使用来自“foods”数组的“favorite”状态创建,并作为来自 App.vue 的 prop“is-favorite”发送,所以我们只需从 v-show 引用 FoodItem.vue 中的这个“isFavorite”prop,其中 <img> 元素用于更新图像:

<img src="/img_quality.svg" v-show="isFavorite">

我们还可以删除 FoodItem.vue 中的“foodIsFavorite”数据属性,因为它不再使用。

示例
在此最后的示例代码中,可以以与之前类似的方式切换食物的收藏状态,但现在收藏状态在 App.vue 内的正确位置进行了修改。

“emits”选项

以我们在 FoodItem.vue 组件内声明 props 的方式,我们也可以使用 Vue“emits”选项记录组件发出的内容。

Props 必须在组件中声明,而 emits 则建议记录下来。

这就是我们如何在 FoodItem.vue 组件中记录 emit 的方法

<script>
export default {
props: ['foodName','foodDesc','isFavorite'],
emits: ['toggle-favorite'],
methods: {
toggleFavorite() {
this.$emit('toggle-favorite', this.foodName);
}
}
};
</script>

当 emits 被记录下来后,其他人就可以更轻松地使用该组件。

总结

到此这篇关于前端必知必会之Vue $emit()方法详解的文章就介绍到这了,更多相关前端Vue $emit()方法内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue-admin-box第一步npm install时报错的处理

    vue-admin-box第一步npm install时报错的处理

    这篇文章主要介绍了vue-admin-box第一步npm install时报错的处理方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • Vue创建头部组件示例代码详解

    Vue创建头部组件示例代码详解

    本文通过实例代码给大家介绍了Vue创建头部组件的相关知识,非常不错,具有一定的参考借鉴价值 ,需要的朋友可以参考下
    2018-10-10
  • Vue实现全选多个选择框

    Vue实现全选多个选择框

    使用v-model绑定布尔变量实现全选功能:定义数组存储状态,使用v-for循环渲染选择框,绑定状态;添加全选复选框,绑定布尔变量;使用watch监听全选复选框状态变化,更新数组中每一项的状态
    2025-01-01
  • vue项目打包为APP,静态资源正常显示,但API请求不到数据的操作

    vue项目打包为APP,静态资源正常显示,但API请求不到数据的操作

    这篇文章主要介绍了vue项目打包为APP,静态资源正常显示,但API请求不到数据的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-09-09
  • vue+elementui实现选项卡功能

    vue+elementui实现选项卡功能

    这篇文章主要为大家详细介绍了vue+elementui实现选项卡功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-03-03
  • 一篇文章带你搞懂VUE基础知识

    一篇文章带你搞懂VUE基础知识

    这篇文章主要介绍了vue 组件基础知识的相关资料,帮助大家更好的理解和使用vue的组件,感兴趣的朋友可以了解下
    2021-11-11
  • Vue多页项目实现在每次版本更新时做提示的解决方案

    Vue多页项目实现在每次版本更新时做提示的解决方案

    项目中使用懒加载方式加载组件,在新部署镜像后,由于浏览器缓存又去加载旧的js chunk,但是之时旧的js chunk已经不存在,加载不出来造成bug,所以本文给大家介绍了Vue多页项目实现在每次版本更新时做提示的解决方案,需要的朋友可以参考下
    2025-11-11
  • vue 组件通信的多种方式

    vue 组件通信的多种方式

    这篇文章主要介绍了vue 组件通信的几种方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-03-03
  • Vue3中引入scss文件的方法步骤

    Vue3中引入scss文件的方法步骤

    这篇文章主要给大家介绍了关于Vue3中引入scss文件的方法步骤,在实际项目中,各种样式往往有很多重复的情况,为了能够使样式的后续开发和维护更加惬意,将这些共同的代码进行命名然后调用这些变量是一个很好的选择,需要的朋友可以参考下
    2023-08-08
  • 如何利用vite快速搭建vue3项目

    如何利用vite快速搭建vue3项目

    这篇文章主要介绍了如何利用vite快速搭建vue3项目问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-03-03

最新评论