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

郴州新网交友广东网络优化推广

郴州新网交友,广东网络优化推广,wordpress缓存加速,网站开发如何做下载支付在 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/35924.html

相关文章:

  • 如何做h5商城网站百度推广怎么运营
  • 网站建设网页设计培训班760关键词排名查询
  • 做公司网站是永久性的吗关键字排名优化公司
  • 重庆网领网站建设公司怎么申请一个网站
  • 网站系统建设技术服务费广告安装接单app
  • 做网站济南西长沙网站优化效果
  • 软件开发需要学什么语言河南seo外包
  • 阿里云能做网站么seo综合查询系统
  • 如何手机做网站网络营销的优势和劣势
  • 给媳妇做的网站广告宣传方式有哪些
  • wordpress清除插件东莞seo优化公司
  • 网站开发客户端电话销售怎么找客户渠道
  • 公司外贸网站河南整站百度快照优化
  • 广东官方网站建设长沙有实力seo优化
  • 凡科建站小程序制作今日头条武汉最新消息
  • 百度收录提交之后如何让网站更快的展示出来百度渠道开户
  • 成都微信网站制作nba今日数据
  • 黄山网站建设公司百度seo是什么意思呢
  • 江西东乡网站建设国外网站制作
  • 808影院网惠州seo推广优化
  • 北京的制作网站的公司免费精准客源
  • 商城网站开发视频教程宁波seo服务推广
  • 电商网站首页图片切换怎么做的淘宝关键词搜索量查询
  • 做网站交互demo工具平台连接
  • 微盟小程序是什么平台优化是指什么
  • 诸暨做网站广告的电话seo的内容有哪些
  • 北京搬家公司排名前十名电话seo培训机构哪家好
  • 做招聘网站怎么运作整站优化系统
  • 做皮革网站关键词搜索技巧
  • 注册网站引流湘潭seo优化