您现在的位置是:网站首页> 编程资料编程资料
详解Vue3 SFC 和 TSX 方式调用子组件中的函数_vue.js_
2023-05-24
380人已围观
简介 详解Vue3 SFC 和 TSX 方式调用子组件中的函数_vue.js_
在开发中会遇到这样的需求:获取子组件的引用,并调用子组件中定义的方法。如封装了一个表单组件,在父组件中需要调用这个表单组件的引用,并调用这个表单组件的校验表单函数或重置表单函数。要实现这个功能,首先要在子组件中暴露父组件需要调用的函数,然后去父组件中获取子组件的引用,最后通过子组件的引用调用子组件暴露的方法。
1 子组件暴露方法
1.1 SFC(.vue)暴露方法
在使用 .vue 定义的组件中,setup 中提供了 defineExpose() 方法,该方法可以将组件内部的方法暴露给父组件。
创建子组件 demo-component-sfc.vue:
demo component sfc
1.2 TSX(.tsx)暴露方法
使用 .tsx 方式定义的组件,也是通过参数 context 中的 expose() 方法暴露组件内容的方法。
创建子组件 demo-component-tsx.tsx:
import { defineComponent } from 'vue' export default defineComponent({ name: 'demo-component-tsx', setup (props, context) { const demoFun = (str: string) => { console.log('demo component tsx', str) } // 使用 expose 暴露组件内部的方法 context.expose({ demoFun }) return () => ( demoFun('child')}>demo component tsx ) } }) 2 父组件调用子组件中的方法
2.1 SFC(.vue)调用
在 .vue 文件中获取组件引用首先定义一个 ref 变量,然后为子组件设置 ref 属性。ref 属性值与变量名要保持一致。
import { defineComponent } from 'vue' export default defineComponent({ name: 'demo-component-tsx', setup (props, context) { const demoFun = (str: string) => { console.log('demo component tsx', str) } // 使用 expose 暴露组件内部的方法 context.expose({ demoFun }) return () => ( demoFun('child')}>demo component tsx ) } }) 如上面的代码所示:第一个子组件的 ref 属性值为 sfcRef,定义的变量名也是 sfcRef。在父组件中便可以使用 sfcRef 调用子组件的 demoFun 方法了。
2.2 TSX(.tsx)调用
在 .tsx 中获取组件的引用更简单,首先定义一个 ref 变量,然后将该变量设置给子组件的 ref 属性即可。
import { defineComponent, ref } from 'vue' import DemoComponentSfc from '@/components/ref/demo-component-sfc.vue' import DemoComponentTsx from '@/components/ref/demo-component-tsx' export default defineComponent({ name: 'demo-ref-tsx', setup () { const sfcRef = ref() const onBtnClick1 = () => { if (sfcRef.value) { sfcRef.value && sfcRef.value.demoFun('parent') } } const tsxRef = ref() const onBtnClick2 = () => { if (tsxRef.value) { tsxRef.value && tsxRef.value.demoFun('parent') } } return () => ( <>parent button parent button > ) } }) 两者实现效果一致:

到此这篇关于Vue3 SFC 和 TSX 方式调用子组件中的函数的文章就介绍到这了,更多相关Vue调用子组件中的函数内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
相关内容
- ant-design-vue中的table自定义格式渲染解析_vue.js_
- React 模块联邦多模块项目实战详解_React_
- ant-design-vue中设置Table每页显示的条目数量方式_vue.js_
- Ant Design Vue中的table与pagination的联合使用方式_vue.js_
- ant design vue的table取消自带分页问题_vue.js_
- JavaScript中net::ERR_CONNECTION_REFUSED解决方法大全_javascript技巧_
- Vue electron前端开启局域网接口实现流程详细介绍_vue.js_
- Vue全局监测错误并生成错误日志实现方法介绍_vue.js_
- Vant实现上传多个图片或视频,更改视频预览图_vue.js_
- React hook超详细教程_React_
