问题:Vue3 监听来自动态创建的子组件的事件,$on 替换

我正在动态创建一个 Vue 组件,我想监听它发出的事件。我知道您可以在标记中使用@eventName,但我正在使用createApp创建组件。

  const div = document.createElement('div');
  this.$refs.login.appendChild(div);

  let props = {
     /** some props **/
  };

  createApp(Component, props,).mount(div);

这就是我创建Component的方式。这个答案这里适用于我的问题,但它适用于 Vue2 并且$on已在 Vue3 中删除。

如何使用 Vue3 实现这一点?

解答

您可以使用渲染函数 (h)添加事件处理程序。h的第二个参数是一个对象,其以"on"开头的键被视为事件处理程序。例如,要为click事件和名为my-event的事件添加处理程序:

import { h } from 'vue'

const comp = h(Component, {
  onClick: e => console.log('click', e),
  onMyEvent: e => console.log('my-event', e),
})
createApp(comp, props).mount(div)

演示 1

如果您的项目支持JSX,则等效为:

const comp = <Component onClick={e => console.log('click', e)}
                        onMyEvent={e => console.log('my-event', e)} />
createApp(comp, props).mount(div)

演示 2

Logo

Vue社区为您提供最前沿的新闻资讯和知识内容

更多推荐