如何在 ReactJS 中创建对话框?


对话框类似于 ReactJS 中的模态框的弹出框。在原生 JavaScript 中,您可能已经使用了 alert() 方法,该方法允许我们在警示框中显示警示消息。此外,原生 JavaScript 还提供了确认框和提示框来获取用户输入。

对话框还允许我们执行所有操作。我们可以根据需要将普通的 HTML 添加到对话框中,它可以作为一个弹出框。

在本教程中,我们将使用各种库来创建对话框。

使用 Material-Ui 库

Material-Ui 库为 React 提供了许多 UI,对话框就是其中之一。我们可以在项目中安装 Material-Ui npm 包并导入它。

用户可以在终端中执行以下命令以在项目中安装 Material-Ui。

npm install @mui/material @emotion/react @emotion/styled

语法

用户可以按照以下语法使用 Material-Ui 库创建对话框。

<Dialog onClose={handleClose} open={open}>
   {/* add HTML here for dialog*/}
</Dialog>

在上面的语法中,我们从 Material-Ui 导入了 Dialog 并将其用作组件。此外,我们需要将 open 的值作为 prop 传递以处理对话框的显示和隐藏。

示例 1 的步骤

  • 步骤 1 − 从 Material-Ui 库导入 Dialog 和 DialogTitle 组件。

  • 步骤 2 − 在我们的应用程序中使用 Dialog 组件添加对话框。此外,在 Dialog 组件内部使用 DialogTitle 组件为对话框创建标题。

  • 步骤 3 − 此外,将 open 变量作为 Dialog 的 prop 传递,表示对话框是打开还是关闭。此外,当 onClose 事件触发时,我们将调用 handleClose() 函数。

  • 步骤 4 − 在 handleClose() 函数中,使用 handleDisplay() 函数并将 openDialog 变量的值设置为 false 以隐藏对话框。

  • 步骤 5 − 此外,创建一个按钮以打开对话框。当用户单击该按钮时,它应该调用 openDialogBox() 函数,该函数将 openDialog 变量的值设置为 true。

示例 1

在下面的示例中,我们使用 Material-UI 库创建了简单的对话框。我们创建了各种函数来隐藏和显示对话框。此外,我们在 Dialog 组件内部添加了行 HTML 并设置了一些样式。

import * as React from "react";
import DialogTitle from "@mui/material/DialogTitle";
import Dialog from "@mui/material/Dialog";
import { height } from "@mui/system";

export default function App(props) {
   const [openDialog, handleDisplay] = React.useState(false);

   const handleClose = () => {
      handleDisplay(false);
   };

   const openDialogBox = () => {
      handleDisplay(true);
   };
   const dialogStyle = {
      padding: "20px",
   };
   const buttonStyle = {
      width: "10rem",
      fontsize: "1.5rem",
      height: "2rem",
      padding: "5px",
      borderRadius: "10px",
      backgroundColor: "green",
      color: "White",
      border: "2px solid yellow",
   };
   return (
      <>
         <h2>
            Using the <i> Material-Ui library </i> to create a dialog box in ReactJs.
         </h2>
         <button style = {buttonStyle} onClick = {openDialogBox}>
            Open Dialog
         </button>
         <Dialog onClose = {handleClose} open = {openDialog}>
            <DialogTitle> Demo Dialog </DialogTitle>
            <h3 style = {dialogStyle}>
               Click outside of the dialog to close the Dialog box.
            </h3>
         </Dialog>
      </>
   );
}

输出

示例 2

在下面的示例中,我们使用了 Material-Ui 库来创建确认框。确认框包含确认和取消按钮。因此,无论用户按下哪个按钮,我们都可以根据该按钮执行某些操作。

在这里,即使用户单击确认框,我们也只会关闭确认框。但是,开发人员可以创建单独的函数并分别处理确认按钮的点击,而不是仅仅关闭确认对话框。

import * as React from "react";
import DialogTitle from "@mui/material/DialogTitle";
import Dialog from "@mui/material/Dialog";

export default function App(props) {
   const [openDialog, handleDisplay] = React.useState(false);

   const handleClose = () => {
      handleDisplay(false);
   };

   const openDialogBox = () => {
      handleDisplay(true);
   };
   const buttonStyle = {
      width: "10rem",
      fontsize: "1.5rem",
      height: "2rem",
      padding: "5px",
      borderRadius: "10px",
      backgroundColor: "green",
      color: "White",
      border: "2px solid yellow",
   };
   const divStyle = {
      display: "flex",
      felxDirection: "row",
      position: "absolute",
      right: "0px",
      bottom: "0px",
      // padding: "1rem",
   };
   const confirmButtonStyle = {
      width: "5rem",
      height: "1.5rem",
      fontsize: "1rem",
      backgroundColor: "grey",
      color: "black",
      margin: "5px",
      borderRadius: "10px",
      border: "1px solid black",
   };
   return (
      <>
         <h2>
            Using the <i> Material-Ui library </i> to create a confirm dialog box in ReactJs.
         </h2>
         <button style = {buttonStyle} onClick = {openDialogBox}>
            Open Dialog
         </button>
         <Dialog onClose = {handleClose} open = {openDialog}>
            <DialogTitle> Confirm Dialog </DialogTitle>
            <h3 style = {{ marginTop: "-10px", padding: "5px 10px" }}>
                  Are you sure to delete the item? {" "}
            </h3>
            <br></br>
            <div style = {divStyle}>
               <button style = {confirmButtonStyle} onClick = {handleClose}>
                  Confirm
               </button>
               <button style = {confirmButtonStyle} onClick = {handleClose}>
                  Cancel
               </button>
            </div>
         </Dialog>
      </>
   );
}

输出

在本教程中,我们看到了使用 Material-Ui 库创建各种对话框的两个示例。但是,用户还可以使用 react-js-dialog-box 库,该库允许开发人员创建和自定义对话框。

更新于: 2023 年 2 月 16 日

12K+ 次浏览

开启你的 职业生涯

通过完成课程获得认证

开始学习
广告