当前位置: 首页 > wzjs >正文

制作软件的网站神马关键词快速排名软件

制作软件的网站,神马关键词快速排名软件,阻断艾滋病的药有哪些,苏州网站的优化在 Vue 3 中,emits 是一个组件选项,用于声明组件可以触发的自定义事件。这有助于组件间的通信,特别是子组件向父组件传递数据。 以下是 emits 的基本用法和示例: 1. 声明自定义事件 你可以在组件中使用 emits 选项来声明可以触…

在 Vue 3 中,emits 是一个组件选项,用于声明组件可以触发的自定义事件。这有助于组件间的通信,特别是子组件向父组件传递数据

以下是 emits 的基本用法和示例:

1. 声明自定义事件

你可以在组件中使用 emits 选项来声明可以触发的事件

数组形式–数组形式适用于不需要进行参数验证的场景:

export default {emits: ['customEvent1', 'customEvent2'],methods: {triggerEvent1() {this.$emit('customEvent1', 'Event 1 triggered');},triggerEvent2() {this.$emit('customEvent2', 'Event 2 triggered');}}
};

对象形式–对象形式允许你对事件进行更详细的验证:

export default {emits: {customEvent: (payload) => {return typeof payload === 'string';}},methods: {triggerEvent() {this.$emit('customEvent', 'Valid payload');}}
};

2. 触发事件

在子组件中,使用 this.$emit 方法触发声明的事件:

<template><button @click="triggerEvent">Trigger Event</button>
</template><script>
export default {emits: ['customEvent'],methods: {triggerEvent() {this.$emit('customEvent', 'Event triggered');}}
};
</script>

父组件监听事件 在父组件中,使用 v-on 或 @ 指令监听子组件的事件:

<template><child-component @customEvent="handleEvent" />
</template><script>
import ChildComponent from './ChildComponent.vue';export default {components: {ChildComponent},methods: {handleEvent(message) {console.log(message); // 输出: 'Event triggered'}}
};
</script>

4. 使用 defineEmits(组合式 API)

组合式 API 中,可以使用 defineEmits 函数来定义事件

<template><button @click="triggerEvent">Trigger Event</button>
</template><script setup>
import { defineEmits } from 'vue';const emit = defineEmits(['customEvent']);
// 数组形式
const emitOther = defineEmits(['increment', 'decrement']);// 对象形式
const emit = defineEmits({updateCount: (newCount) => {return typeof newCount === 'number';}
});
const triggerEvent = () => {emit('customEvent', 'Event triggered');
};
</script>

对象形式进行一次完整的表达

<template><button @click="triggerEvent">Trigger Event</button>
</template><script setup>
import { ref } from 'vue';const count = ref(0);const emit = defineEmits({updateCount: (newCount) => {return typeof newCount === 'number';}
});const triggerEvent = () => {count.value++;emit('updateCount', count.value);
};
</script>

TS的写法 在 TypeScript 中,你可以使用类型声明来定义事件参数的类型:

<script setup lang="ts">
const emit = defineEmits<{(e: 'change', id: number): void;(e: 'update', value: string): void;
}>();const triggerChange = (id: number) => {emit('change', id);
};const triggerUpdate = (value: string) => {emit('update', value);
};
</script>

注意事项

  • 事件验证:在对象形式中,验证函数返回 false 时,事件将不会被触发 。
  • 原生事件:在 Vue 3 中,可以直接在组件上监听原生事件,无需使用 .native 修饰符 。
http://www.dtcms.com/wzjs/1356.html

相关文章:

  • 网站建设遵循原则网络工具
  • 建设银行宁波分行招聘网站关键词的优化和推广
  • 有什么网站可以做电子如何让百度快速收录网站文章
  • 用什么软件做网站seo好链接推广平台
  • 做类似简书的网站360安全网址
  • 网站要什么软件做东莞网站公司哪家好
  • 一级域名免费网站怎么申请短视频seo询盘获客系统
  • 怎么做和京东一样网站泉州全网营销推广
  • 网站开发怎么学习全网品牌推广公司
  • 淘宝网站怎样做深圳网站优化推广
  • wordpress命令安装目录结构seo概念的理解
  • 项目网站制作友情链接怎么设置
  • php房产中介网站源码综合权重查询
  • cnzz 网站域名怎么填域名停靠浏览器
  • 个人网站是什么意思今天新闻头条
  • 怎样做电商网站的财务分析沧州网站建设推广
  • 新浪sae wordpressseo网站推广方式
  • 品牌网站建设优化公司广告设计网站
  • 网站点击量 哪里查询拼多多关键词排名查询软件
  • discuz做的网站上传到网站空间的文件百度推广客服电话多少
  • 建站宝盒可以做视频聊天交友网站吗互联网广告精准营销
  • 专业网站建设价格sem广告
  • 企业网站 备案 网站名称网络营销与市场营销的区别
  • wordpress 不支持中文深圳网站seo哪家快
  • 成都sw网站建设站长工具同大全站
  • 自己设置网站免费b站在线观看人数在哪
  • 给客户做网站图片侵权谷歌广告上海有限公司
  • 庆阳网站建设与制作googleplay商店
  • 怎么自己免费创建一个网站爱站网挖掘工具
  • 数码产品网站建设网站开发工程师