Vue 组件传参 emit

emit 属性:用于创建自定义事件,接收子组件传递过来的数据。

注意:如果自定义事件的名称,和原生事件的名称一样,那么只会触发自定义事件。

setup 语法糖写法请见:《Vue3 子传父 组件传参 defineEmits》 

语法格式

// 子组件:创建自定义事件,传递数据
emits: ['自定义事件'],
// 组合式 API 使用
setup(props, context) {
  context.emit("自定义事件", 数据1, 数据2);
},
// 选项式 API 使用
this.$emit("自定义事件", 数据1, 数据2);

// 父组件:绑定自定义事件,接收数据
<组件标签 @自定义事件="函数名"></组件标签>
// JS 代码
const 函数名 = (参数1, 参数2) => {
  console.log(参数1, 参数2);
}

组合式 API 写法

一、子组件:创建自定义事件,传递数据。

 

<template>
  <h3>我是子组件</h3>
</template>

<script>
import { ref } from "vue";
export default {
  // 创建自定义事件 myEvent
  emits: ["myEvent"],
  setup(props, context) {
    let name = ref("张三");
    // 使用 myEvent 自定义事件,传递数据
    context.emit("myEvent", name.value, 999);
    return {};
  },
};
</script>

:需要在 setup 函数中接收一个 context 参数,才能在 JS 中使用。

二、父组件:给组件标签绑定自定义事件,接收数据。

<template>
  <h3>我是父组件</h3>
  <p>{
  { title }}</p>
  <hr />
  <!-- 绑定自定义事件 -->
  <Child @myEvent="add"></Child>
</template>

<script>
import Child from '../components/Child';
import { ref } from 'vue';
export default {
  components: { Child },
  setup() {
    let title = ref();
    // 接收数据
    const add = (name, num) => {
      title.value = name;
      console.log('我是父组件', name, num);
    }
    return { title, add }
  }
}
</script>

:子组件使用自定义事件后,父组件中的事件函数会自动执行。

三、最终效果。

原创作者:吴小糖

创作时间:2023.12.15 

相关推荐

  1. vue

    2023-12-16 06:52:03       9 阅读
  2. Vue】组件

    2023-12-16 06:52:03       33 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-16 06:52:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-16 06:52:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-16 06:52:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-16 06:52:03       18 阅读

热门阅读

  1. Oracle的身份证号仿真脱敏算法

    2023-12-16 06:52:03       39 阅读
  2. 四级作文考前积累(个人蒟蒻向)

    2023-12-16 06:52:03       32 阅读
  3. npm详解

    npm详解

    2023-12-16 06:52:03      34 阅读
  4. 探秘npm:解锁前端生态的魔法工具

    2023-12-16 06:52:03       42 阅读
  5. Graylog解决超出ES搜索最大窗口限制问题

    2023-12-16 06:52:03       39 阅读
  6. Graylog 中日志级别及其对应的数字

    2023-12-16 06:52:03       39 阅读
  7. dcf配置解析机制(元数据)

    2023-12-16 06:52:03       40 阅读
  8. FreeSWITCH rtp endpoint recvonly

    2023-12-16 06:52:03       36 阅读
  9. 12.15每日一题(备战蓝桥杯摘花生)

    2023-12-16 06:52:03       34 阅读
  10. ansible crontab任务管理 —— 筑梦之路

    2023-12-16 06:52:03       19 阅读
  11. Ansible的Jinja test

    2023-12-16 06:52:03       25 阅读