react二次封装Modal和Drawer组件

news/2024/7/15 18:13:38 标签: react.js, 前端, 前端框架

目录

  • react二次封装Modal和Drawer组件
    • 01:Modal组件
      • 01-1 BaseModal.jsx
      • 01-2 使用BaseModal组件
      • 01-3 效果
    • 02:Drawer组件
      • 02-1 BaseDrawer.jsx组件
      • 02-2 使用BaseDrawer组件
      • 02-3效果

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效果

在这里插入图片描述


http://www.niftyadmin.cn/n/5235419.html

相关文章

连接oracle报 错误: Undefined Error

如果你的电脑用户名是纯英文&#xff0c;那么这篇文章可能对你没用 ERROR com.alibaba.druid.pool.DruidDataSource - init datasource error, url: jdbc:oracle:thin://192.168.111.86:1521/sjtsoms java.sql.SQLRecoverableException: IO 错误: Undefined Error md&#xff…

模型量化相关知识汇总

量化&反量化 量化操作可以将浮点数转换为低比特位数据表示,比如int8和 uint8. Q(x_fp32, scale, zero_point) round(x_fp32/scale) zero_point,量化后的数据可以经过反量化操作来获取浮点数 x_fp32 (Q - zero_point)* scale pytorch中 quantize_per_tensor的解释 py…

【开源】基于Vue和SpringBoot的校园二手交易系统

项目编号&#xff1a; S 009 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S009&#xff0c;文末获取源码。} 项目编号&#xff1a;S009&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 二手商品档案管理模…

【iOS控件】—— UIPickerView的使用

【iOS控件】—— UIPickerView的使用 一. 简述UIPickerView1. 什么是UIPickerView2. UIPickerView遵守的协议 二. 测试Demo三. 总结 一. 简述UIPickerView 先看一下UIPickerView的效果图&#xff1a; 1. 什么是UIPickerView UIPickerView是iOS平台上的一个用户界面元素&am…

vue 使用decimal.js 解决小数相加合计精确度丢失问题

安装依赖 decimal.js npm install --save decimal.js 封装 在utils文件夹下创建decimal.js文件 import { Decimal } from decimal.js export function add (x, y) {if (!x) {x 0}if (!y) {y 0}const xx new Decimal(x)const yy new Decimal(y)return xx.plus(yy).toNumbe…

SCAU:分期还款(加强版)

分期还款(加强版) Time Limit:1000MS Memory Limit:65535K 题型: 编程题 语言: G;GCC;VC 描述 从银行贷款金额为d&#xff0c;准备每月还款额为p&#xff0c;月利率为r。请编写程序输入这三个数值&#xff0c;计算并输出多少个月能够还清贷款&#xff0c;输出时保留1位小…

设计模式 -职责链模式

定义 职责链模式是一种对象行为型模式&#xff0c;它常用于处理具有多个处理者的请求。在一个软件系统中&#xff0c;当一个请求可以被多个对象处理时&#xff0c;这些对象可以组织成一条链&#xff0c;并按照这个链传递请求&#xff0c;从而实现了请求发送者和请求处理者之间…

洛谷 P9516 color C++代码

目录 前言 思路点拨 AC代码 结尾 前言 今天我们来做洛谷上的一道题目。 网址&#xff1a;color - 洛谷 题目&#xff1a; 思路点拨 这题就是if-else判断输入的五个数据和不就OK了&#xff1f; 在这里我的估值是183&#xff08;截止2023.12.3&#xff09;&#xff0c;热…