0

我正在学习 TypeScript 和 React 的开发。我正在将 rsuite 用于图形组件 - 到目前为止,我已经使用了该套件中的大量组件,没有任何问题。但现在我正在尝试创建一个模态对话框,但无法弄清楚如何在我的设置中使用 Modal.* 组件。

我已经尝试了我能找到的每一个建议,三重检查了我的导入和语法,在我看来一切都应该正常工作,但我收到错误消息“JSX 元素类型'Modal.Header'没有任何构造或来电签名。”。Rsuite 声称它完全支持 typescript 和 react 16+,并且该库中的其他组件工作正常,所以我很确定错误就在我身边。

这是有问题的组件:

import React, { Component } from 'react';
import { Modal, Button } from 'rsuite';


class GroupTransactionDialog extends Component<any> {
    render() {
        return <div className="modal-container">
            <Modal open={true} onClose={this.props.onClose}>
                <Modal.Header>
                    <Modal.Title>Modal Title</Modal.Title>
                </Modal.Header>
                <Modal.Body>
                    <p></p>
                </Modal.Body>
                <Modal.Footer>
                    <Button onClick={this.props.onClose} appearance="primary">Save</Button>
                    <Button onClick={this.props.onClose} appearance="subtle">Cancel</Button>
                </Modal.Footer>
      </Modal>
        </div>
    }
}

export default GroupTransactionDialog;

错误如下所示:

TypeScript error in /home/johny/Developement/Js/finance2/src/components/GroupTransactionDialog.tsx(9,18):
JSX element type 'Modal.Header' does not have any construct or call signatures.  TS2604

     7 |         return <div className="modal-container">
     8 |             <Modal open={true} onClose={this.props.onClose}>
  >  9 |                 <Modal.Header>
       |                  ^
    10 |                     <Modal.Title>Modal Title</Modal.Title>
    11 |                 </Modal.Header>
    12 |                 <Modal.Body>

任何帮助是极大的赞赏!

4

1 回答 1

0

由于 Linda Paiste 的评论,我发现我使用的是 rsuite 5.0.0 alpha 版本而不是稳定版本。重新安装 4.9.3 后,modal 开始按预期工作!

于 2021-04-16T15:45:40.737 回答