对话框组件中的动态内容

时间:2019-01-18 14:36:00

标签: javascript css reactjs primereact

你好,我尝试使用动态照片尺寸内容的Dialog中的主要react组件创建数据视图。默认情况下,带有滚动条并位于屏幕中央的照片弹出窗口。 如何在屏幕上方使用动态尺寸且没有滚动条的方式制作图像。

我尝试使用最大/最小身高和体重,但没有结果。 发现“动态内容可能会将对话框边界移到视口之外。常见的解决方案是通过contentStyle定义max-height,以便更长的内容显示滚动条。”来自https://www.primefaces.org/primereact/#/dialog 但是如何实现。

        <Dialog header="Client Details"
                visible={this.state.visible}
                modal={true}
                onHide={() => this.setState({visible: false})}>
            {this.renderClientDialogContent()}
        </Dialog>


renderClientDialogContent() {
    if (this.state.selectedClient) {
        return (
            <div className="p-grid" style={{fontSize: '16px', textAlign: 'center', padding: '20px', maxHeight:'800px', maxWidth:'700px', minWidth:'300px'}}>
                <div className="p-col-36" style={{textAlign: 'center'}}>
                    <img src={this.state.selectedClient.bigPhotoLink}
                         alt={this.state.selectedClient.name} />
                </div>

                <div className="p-col-12">{this.state.selectedClient.name}</div>

                <div className="p-col-12">{this.state.selectedClient.description}</div>
            </div>
        );
    }
    else {
        return null;
    }
}

如何使对话框大小等于照片大小。 enter image description here

1 个答案:

答案 0 :(得分:0)

只需将contentStyle对象与所需的max-height一起传递(与使用style属性的方式相同):

<Dialog
    contentStyle={{ maxHeight: "300px" }}
    header="Client Details"
    visible={this.state.visible}
    modal={true}
    onHide={() => this.setState({visible: false})}
    >
    {this.renderClientDialogContent()}
</Dialog>