浅析Vue.js中$emit和$on的用法和区别

 更新时间:2023年07月21日 11:13:18   作者:程序媛-徐师姐  
在 Vue.js 中,$emit和$on方法是两个常用的方法,用于实现组件间的通信,虽然它们的名字很相似,但它们的作用和用法有所不同,本文将介绍$emit和$on方法的区别,并通过代码示例来说明它们的用法,感兴趣的朋友可以参考下

Vue.js 中的 $emit 和 $on 方法有什么区别?

$emit

$emit 方法是 Vue.js 中用于触发自定义事件的方法。它可以让我们在一个组件中触发一个自定义事件,并向父组件或祖先组件派发这个事件。在触发事件时,我们可以传递任意数量的参数,这些参数可以在监听事件的组件中获取到。

下面是一个使用 $emit 方法的示例代码:

// 定义一个名为 myButton 的组件
Vue.component('my-button', {
  template: `
    <button @click="onClick">Click me</button>
  `,
  methods: {
    onClick: function () {
      this.$emit('clicked', 'Hello, world!')
    }
  }
})
// 定义一个名为 myApp 的组件,并在其中监听 myButton 组件的 clicked 事件
Vue.component('my-app', {
  template: `
    <div>
      <my-button @clicked="onButtonClicked"></my-button>
      <p>{{ message }}</p>
    </div>
  `,
  data: function () {
    return {
      message: ''
    }
  },
  methods: {
    onButtonClicked: function (msg) {
      this.message = msg
    }
  }
})

在上面的代码中,我们定义了一个名为 myButton 的组件。这个组件中有一个按钮,当用户点击按钮时,会触发一个名为 clicked 的自定义事件,并将字符串 ‘Hello, world!’ 作为参数传递给事件处理函数。

然后,我们定义了一个名为 myApp 的组件,并在其中监听 myButton 组件的 clicked 事件。当 myButton 组件触发 clicked 事件时,myApp 组件中的 onButtonClicked 方法就会被调用,并将传递给事件处理函数的参数赋值给组件中的 message 数据,从而更新视图。

需要注意的是,$emit 方法只能向父组件或祖先组件派发事件,不能向子组件或后代组件派发事件。这是因为 Vue.js 中的事件传递是基于 DOM 树的,父组件可以通过 props 将数据传递给子组件,但是子组件不能直接向父组件传递数据。

$on

$on 方法是 Vue.js 中用于监听自定义事件的方法。它可以让我们在一个组件中监听一个自定义事件,并在事件触发时执行一个回调函数。在监听事件时,我们可以指定一个可选的参数,用于限制事件的作用域,使得事件只在指定的组件中有效。

下面是一个使用 $on 方法的示例代码:

// 定义一个名为 myButton 的组件,并在其中触发一个 clicked 事件
Vue.component('my-button', {
  template: `
    <button @click="onClick">Click me</button>
  `,
  methods: {
    onClick: function () {
      this.$emit('clicked', 'Hello, world!')
    }
  },
  created: function () {
    this.$emit('clicked', 'Hello, world!')
  }
})
// 定义一个名为 myApp 的组件,并在其中监听 myButton 组件的 clicked 事件
Vue.component('my-app', {
  template: `
    <div>
      <my-button></my-button>
      <p>{{ message }}</p>
    </div>
  `,
  data: function () {
    return {
      message: ''
    }
  },
  created: function () {
    this.$on('clicked', this.onButtonClicked)
  },
  methods: {
    onButtonClicked: function (msg) {
      this.message = msg
    }
  }
})

在上面的代码中,我们定义了一个名为 myButton 的组件,并在其中触发一个 clicked 事件。在 myApp 组件中,我们使用 $on 方法监听 myButton 组件的 clicked 事件,并指定该事件只在 myApp 组件中有效。当 myButton 组件触发 clicked 事件时,myApp 组件的 onButtonClicked 方法就会被调用,并将传递给事件处理函数的参数赋值给组件中的 message 数据,从而更新视图。

需要注意的是,$on 方法只能监听已经派发的事件,不能监听尚未派发的事件。因此,在上面的代码中,我们在 myButton 组件的 created 钩子函数中手动触发了 clicked 事件,以便 myApp 组件可以监听到该事件。

区别

$emit和on方法的区别主要在于它们的作用和用法。 on方法的区别主要在于它们的作用和用法。on方法的区别主要在于它们的作用和用法。emit方法用于触发自定义事件并向父组件或祖先组件派发该事件,而 on方法用于监听自定义事件并在事件触发时执行回调函数。 on方法用于监听自定义事件并在事件触发时执行回调函数。on方法用于监听自定义事件并在事件触发时执行回调函数。emit方法必须在组件内部使用,而$on方法可以在任何地方使用,包括组件内部和组件外部。

另外,$emit方法可以传递任意数量的参数,而on方法只能传递一个参数,这个参数就是事件处理函数在接收到事件时传递的数据。 on方法只能传递一个参数,这个参数就是事件处理函数在接收到事件时传递的数据。on方法只能传递一个参数,这个参数就是事件处理函数在接收到事件时传递的数据。emit方法只能向父组件或祖先组件派发事件,而$on方法可以监听任意组件派发的事件。

总结

$emit 和on方法是Vue . js中用于实现组件间通信的两个重要方法。 on方法是Vue.js中用于实现组件间通信的两个重要方法。on方法是Vue.js中用于实现组件间通信的两个重要方法。emit方法用于触发自定义事件并向父组件或祖先组件派发该事件,而on方法用于监听自定义事件并在事件触发时执行回调函数。on方法用于监听自定义事件并在事件触发时执行回调函数。on方法用于监听自定义事件并在事件触发时执行回调函数。emit方法必须在组件内部使用,而on方法可以在任何地方使用,包括组件内部和组件外部。 on方法可以在任何地方使用,包括组件内部和组件外部。on方法可以在任何地方使用,包括组件内部和组件外部。emit方法可以传递任意数量的参数,而on方法只能传递一个参数。on方法只能传递一个参数。on方法只能传递一个参数。emit方法只能向父组件或祖先组件派发事件,而 $on 方法可以监听任意组件派发的事件。

在实际开发中,$emit和$on方法经常被用来实现父子组件之间的数据传递和交互。通过熟练掌握这两个方法的用法,我们可以更加灵活地组织组件间的关系,提高组件的复用性和可维护性。

以上就是浅析Vue.js中$emit和$on的用法和区别的详细内容,更多关于Vue.js中$emit和$on的资料请关注脚本之家其它相关文章!

相关文章

  • vue3 头像上传 组件功能实现

    vue3 头像上传 组件功能实现

    这篇文章主要介绍了vue3头像上传组件功能,用到了自定义组件v-model的双向绑定,使用axios + formData 上传文件,本文结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • Vue 实现一个命令式弹窗组件功能

    Vue 实现一个命令式弹窗组件功能

    这篇文章主要介绍了vue实现命令式弹窗组件功能,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • elementui实现预览图片组件二次封装

    elementui实现预览图片组件二次封装

    这篇文章主要介绍了elementui实现预览图片组件二次封装的方法 ,帮助大家更好的理解和使用vue框架,感兴趣的朋友可以了解下
    2020-12-12
  • vue里面使用mui的弹出日期选择插件实例

    vue里面使用mui的弹出日期选择插件实例

    今天小编就为大家分享一篇vue里面使用mui的弹出日期选择插件实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-09-09
  • 前端必知必会之Vue v-if指令详解

    前端必知必会之Vue v-if指令详解

    这篇文章主要介绍了前端必知必会之Vue v-if指令的相关资料,Vue中的条件渲染指令v-if、v-else-if和v-else用于根据条件动态创建HTML元素,通过使用比较运算符和逻辑运算符,可以编写复杂的条件逻辑,需要的朋友可以参考下
    2025-02-02
  • Vue下拉框值变动事件传多个参数方式

    Vue下拉框值变动事件传多个参数方式

    这篇文章主要介绍了Vue下拉框值变动事件传多个参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-04-04
  • vue3中虚拟dom的介绍与使用详解

    vue3中虚拟dom的介绍与使用详解

    Vue 是如何将一份模板转换为真实的 DOM 节点的,又是如何高效地更新这些节点的呢,这些都离不开虚拟dom这个概念,下面我们就来了解下虚拟dom这个概念以及它是什么吧
    2024-01-01
  • vue实现手风琴效果

    vue实现手风琴效果

    这篇文章主要为大家详细介绍了vue实现手风琴效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • 详解vuex的简单todolist例子

    详解vuex的简单todolist例子

    这篇文章主要介绍了详解vuex的简单todolist例子,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-07-07
  • vue路由相对路径跳转方式

    vue路由相对路径跳转方式

    这篇文章主要介绍了vue路由相对路径跳转方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-08-08

最新评论