react --封装Dialog弹框

在这里插入图片描述

Dialog.js
import React, { Component, Children } from "react";
import { createPortal } from "react-dom";
import "../static/css/Dialog.scss"
export default class Dialog extends Component {
  constructor(props) {
    super(props);
    const doc = window.document;
    this.node = doc.createElement("div");
    doc.body.appendChild(this.node);
  }
  componentWillUnmount() {
    window.document.body.removeChild(this.node);
  }
  render() {
    const { children, hideDialog, hide } = this.props;
    let tem = hide ? "hidden" : "";
    console.log("hide", tem);
    return createPortal(
      <div className="dialogBox" style={{ visibility: tem }}>
        <div className="dialog">
          {children}
          <button onClick={hideDialog}>close</button>
        </div>
      </div>,
      this.node
    );
  }
}

Dialog.scss
.dialogBox {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background: rgba($color: #000000, $alpha: 0.5);
  display: flex;
  justify-content: center;
  align-items: center;
  .dialog{
  width: 50%;
  height: 50%;
  text-align: center;;
  background-color: #fff;
  }
}
DialogPage.js 使用
/*
 * @Author: shihaixia
 * @Date: 2022-02-24 09:58:02
 * @Description: 
 */
import React, { Component } from "react";
import { Button } from "antd";
import Dialog from "../components/Dialog";

export default class DialogPage extends Component {
  constructor(props) {
    super(props);
    this.state = {
      showDialog: false,
    };
  }
  handleShowDialog = () => {
    this.setState({
      showDialog: !this.state.showDialog,
    });
  };
  render() {
    const { showDialog } = this.state;
    return (
      <div className="dialogPage">
        <h1>DialogPage</h1>
        <Button onClick={this.handleShowDialog}>切换</Button>
        {showDialog && (
          <Dialog hideDialog={this.handleShowDialog} hide={false}>
            <h3>标题</h3>
            <p>这是一个弹窗</p>
          </Dialog>
        )}
      </div>
    );
  }
}

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值