async没有了await会发生什么?实际问题

关于这个问题

js 复制代码
// 父组件
const getFormData = async () => { 
    importForm.validateFields().then((values) => { 
    const params = { 
        MaNO: values?.MaNO, 
        InvoiceNO: values.InvoiceNO, 
        Destination: values?.Destination 
    } 
    console.log('params111'); 
    return params 
    }
    )
}

<ImportFileComponent 
    getFormData={getFormData} 
     <Button>按钮<Button>
</ImportFileComponent>
js 复制代码
// 子组件
const onConfirm = async () => { 
    const dataValue = getFormData?.() 
    console.log(dataValue, 'dataValue'); 
}

1.抛出问题:当父组件传这个方法给子组件调用的时候,拿不到返回的params,而是一个promise

2.问题原因:父组件的async走完之后并没有等到await,返回的值在.then()里面的,所以导致他实际返回的是一个Promise

3.解决问题:既然找到了问题所在,那么直接使用await拿到值,使用同步的方式处理异步的代码,或者可以使用两个then,但是那样有些麻烦。

所以,正确的写法是这样的,父组件的方法处理下写

js 复制代码
 // 父组件
 const getFormData = async () => { 
    const values = await importForm.validateFields() 
    const params = {
        MaNO: values?.MaNO, 
        InvoiceNO: values.InvoiceNO, 
        Destination: values?.Destination 
    } 
    console.log('params111'); 
    return params
}
    

结束~

相关推荐
默默地写代码6 分钟前
微信小程序 新版canvas绘制名片
前端·javascript·微信小程序
weixin_456588156 分钟前
【web 安全】从 HTTP 无状态到现代身份验证机制
前端·web安全·http
luckymiaow11 分钟前
「从零到一打造现代桌面应用:基于 Electron + Vite + Vue3 + TypeScript 的高效开发模板」
前端·vue.js
layman052812 分钟前
Vue 中的配置代理
前端·javascript·vue.js
parade岁月18 分钟前
关于浏览器跨域的一些知识点
前端
未来之窗软件服务21 分钟前
jquery 赋值时不触发change事件解决——仙盟创梦IDE
前端·javascript·jquery·仙盟创梦ide·东方仙盟
AnyaPapa26 分钟前
【解决方案】Vue 常见问题大全
前端·javascript·vue.js
三小河35 分钟前
在ts 中 对于常见的内置工具类型、类型操作符和关键字简单解释
前端
૮・ﻌ・37 分钟前
前端HTML学习笔记
前端·笔记·html·黑马程序员
用户276920244534641 分钟前
Cesium 三维地球开发:一站式弹窗、坐标转换与可视化扩展(持续进化中)
前端