react二次封装Modal和Drawer组件

react二次封装Modal和Drawer组件

  • npm i styled-components

01:Modal组件

01-1 BaseModal.jsx

import { Modal } from 'antd';
import React, { useState } from 'react';
import styled from "styled-components";
const BaseModal = (props) => {
  const { showModal, setShowModal } = props
  const [confirmLoading,setConfirmLoading] = useState(false) // 确定按钮的loading
  const modalText = '我是内容'
  // 确定 - 涉及异步请求
  const handleOk = () => {
    setConfirmLoading(true);
    setTimeout(() => {
      setShowModal(false)
      setConfirmLoading(false);
    }, 2000);
  };
  // 取消
  const handleCancel = () => {
    setShowModal(false)
  };
  return (
      <CustomModal
        title='标题'
        open={showModal}
        onOk={handleOk}
        confirmLoading={confirmLoading}
        onCancel={handleCancel}
        maskClosable={false}
        okText='确定1'
        cancelText='取消1'
      >
        <p>{modalText}</p>
      </CustomModal>
  );
};
export default BaseModal;

// css
const CustomModal = styled(({ ...props }) => <Modal {...props} />)`
  .ant-modal-body {
    padding: 20px; // 设置自定义的padding值
    background: pink;
  }
`;

01-2 使用BaseModal组件

import { Button } from 'antd';
import React, { useState } from 'react';
import BaseModal from "./BaseModal";

export default function App(props) {
    const [showModal, setShowModal] = useState(false)
    // 打开
    const openModal = () => {
      setShowModal(true)
    }
    return (
        <div className='content'>
          <Button type="primary" onClick={openModal}>
            打开
          </Button>
          <BaseModal showModal={showModal} setShowModal={setShowModal}></BaseModal>
        </div>
    )
}

01-3 效果

在这里插入图片描述

02:Drawer组件

02-1 BaseDrawer.jsx组件

import { Button, Drawer, Space } from "antd";
import React, { useState } from "react";
import styled from "styled-components";

const BaseDrawer = (props) => {
  const { showDrawer, setShowDrawer } = props;
  const [confirmLoading, setConfirmLoading] = useState(false); // 确定按钮的loading
  const modalText = "我是内容";
  // 取消
  const onClose = () => {
    setShowDrawer(false);
  };
  // 确定
  const onSubmit = () => {
    setConfirmLoading(true);
    setTimeout(() => {
      setShowDrawer(false);
      setConfirmLoading(false);
    }, 2000);
  };
  return (
    <CustomDrawer
      title="标题"
      placement="right"
      size="large"
      onClose={onClose}
      open={showDrawer}
      footer={
        <Space style={{ display: "flex", justifyContent: "end" }}>
          <Button onClick={onClose}>取消</Button>
          <Button type="primary" onClick={onSubmit} loading={confirmLoading}>
            确定
          </Button>
        </Space>
      }
      maskClosable={false}
      getContainer={false}
    >
      <p>{modalText}</p>
    </CustomDrawer>
  );
};
export default BaseDrawer;

// css
const CustomDrawer = styled(({ ...props }) => <Drawer {...props} />)`
  .ant-drawer-body {
    padding: 20px; // 设置自定义的padding值
    background: pink;
  }
`;

02-2 使用BaseDrawer组件

import { Button } from 'antd';
import React, { useState } from 'react';
import BaseDrawer from "./BaseDrawer";

export default function App(props) {
    const [showDrawer, setShowDrawer] = useState(false)
    // 打开
    const openDrawer = () => {
      setShowDrawer(true)
    }
    return (
        <div className='content'>
          <Button type="primary" onClick={openDrawer}>
            打开
          </Button>
          <BaseDrawer showDrawer={showDrawer} setShowDrawer={setShowDrawer}></BaseDrawer>
        </div>
    )
}


02-3效果

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值