类型“Promise<Element>”缺少类型“ReactElement<any,any>”中的以下属性

Mse*_*Ali 5 promise typescript reactjs es6-promise

我在尝试渲染 ClientDetails 组件并在 props 中传递 Client 列表时遇到编译问题:

我收到此错误消息:

Type '{ (): Promise<JSX.Element>; propTypes: {}; }' is not assignable to type 'ComponentClass<any, any> | FunctionComponent<any> | ComponentClass<RouteComponentProps<any, StaticContext, {}>, any> | FunctionComponent<...>'.
      Type '{ (): Promise<JSX.Element>; propTypes: {}; }' is not assignable to type 'FunctionComponent<any>'.
        Type 'Promise<Element>' is missing the following properties from type 'ReactElement<any, any>': type, props, key
Run Code Online (Sandbox Code Playgroud)

我的 renderClientsTable 函数:

static async renderClientsTable(clients: Readonly<IClientModel[]>) {
        return (
            <table className='table table-striped' aria-labelledby="tabelLabel">
                <thead>
                    <tr>
                        <th>Id</th>
                        <th>Name</th>
                        <th>Url</th>
                        <th>Status</th>
                    </tr>
                </thead>
                <tbody>
                    { await Promise.all(clients.map(async (cl): Promise<void> => {
                           ( 
                                <>
                                    <ClientDetails id={cl.id} name={cl.name} baseUrl={cl.baseUrl} status={cl.status} /> 
                                </>
                            )
                        }))
                    }
                </tbody>
            </table>
        );
    }
Run Code Online (Sandbox Code Playgroud)

这是我的父组件的代码:

 const ClientsPage = async () => { 
        return (
            <div>
                <Clientslist clients = { this.loadClients() } >
                    {Children}
                </Clientslist>
            </div>
        );
    
        async function loadClients(): Promise<IClientModel[]> {
            const response = await fetch('clients/all', {
                headers: {
                    'Content-Type': 'application/json',
                    'Accept': 'application/json'
                }
            });
            return await response.json();
        }
    };
    
    ...
    
    export default ClientsPage;
Run Code Online (Sandbox Code Playgroud)