React组件封装 -- 弹出对话框

封装一个函数式组件实现前端开发中经常遇到的场景: 点击按钮弹出对话框。此组件可以作为一个模板,具备弹窗的基本功能,遵循基于构件开发的设计原则。

1. 基本结构

  1. 使用antd中的Modal组件构建对话框
  2. 使用antd中的Tooltip组件构建点击按钮的悬浮提示
  3. 使用antd中的Button组件构键打开对话框的按钮
  4. 提供内部强制刷新的方法接口
  5. 提供外部强制刷新的属性接口
  6. 使用css-in-js技术实现Modal样式的自定义

2. 实现代码

js 复制代码
import React, { useState } from 'react';
import { Button, Modal, Tooltip } from 'antd';
import styled from 'styled-components'; 


const CustomModal = styled(Modal)`
  .ant-modal-content {
    border-radius: 8px;
  }

  .ant-modal-header {
    background-color: #f0f0f0;
  }

  .ant-modal-title {
    color: #333;
  }

  .ant-modal-body {
    padding: 20px;
  }

  .ant-modal-footer {
    border-top: none;
  }
`;



function MyComponent({ refreshKey }) {
  const [isModalVisible, setIsModalVisible] = useState(false);
  const [refresh, setRefresh] = useState(false);


  const handleClick = () => {
    setIsModalVisible(true);
  };

  const handleOk = () => {
    setIsModalVisible(false);
  };

  const handleCancel = () => {
    setIsModalVisible(false);
  };

  const refreshComponent = () => {
    setRefresh(prevRefresh => !prevRefresh);
  };

  return (
    <div>
      <Tooltip title="这是一个提示文本">
        <Button onClick={handleClick}>点击弹出对话框</Button>
      </Tooltip>

      <CustomModal 
            title="对话框标题" 
            visible="{isModalVisible}
            onOk={handleOk}
            onCancel={handleCancel}
            okText="确定" 
            cancelText="取消" 
            maskClosable={true}
      >
        <p>这是一个对话框内容</p>
      </CustomModal>
    </div>
  );
}

export default MyComponent;

3. 详细解释

组件功能的详细说明:

jsx 复制代码
import React, { useState } from 'react';
import { Button, Modal, Tooltip } from 'antd';
import styled from 'styled-components';
  • 导入了 ReactuseState 钩子以及 ButtonModalTooltip 组件。
  • 还导入了 styled-components 库用于创建自定义样式组件。
jsx 复制代码
const CustomModal = styled(Modal)`
  .ant-modal-content {
    border-radius: 8px;
  }

  .ant-modal-header {
    background-color: #f0f0f0;
  }

  .ant-modal-title {
    color: #333;
  }

  .ant-modal-body {
    padding: 20px;
  }

  .ant-modal-footer {
    border-top: none;
  }
`;
  • 创建了一个名为 CustomModal 的自定义样式组件。
  • 使用 styled-components 库的语法将 Modal 组件作为基础组件进行样式设置。
  • .ant-modal-content 类选择器设置对话框内容区域的边框圆角为 8px
  • .ant-modal-header 类选择器设置对话框头部区域的背景颜色为 #f0f0f0
  • .ant-modal-title 类选择器设置对话框标题文字的颜色为 #333
  • .ant-modal-body 类选择器设置对话框内容区域的内边距为 20px
  • .ant-modal-footer 类选择器移除对话框底部区域的顶部边框。
jsx 复制代码
function MyComponent({ refreshKey }) {
  const [isModalVisible, setIsModalVisible] = useState(false);
  const [refresh, setRefresh] = useState(false);

  const handleClick = () => {
    setIsModalVisible(true);
  };

  const handleOk = () => {
    setIsModalVisible(false);
  };

  const handleCancel = () => {
    setIsModalVisible(false);
  };

  const refreshComponent = () => {
    setRefresh(prevRefresh => !prevRefresh);
  };

  return (
    <div>
      {/* Tooltip 组件 */}
      <Tooltip title="这是一个提示文本">
        {/* Button 组件 */}
        <Button onClick={handleClick}>点击弹出对话框</Button>
      </Tooltip>

      {/* CustomModal 自定义样式组件 */}
      <CustomModal 
        title="对话框标题" 
        visible={isModalVisible}
        onOk={handleOk}
        onCancel={handleCancel}
        okText="确定"
        cancelText="取消"
        maskClosable={true}
      >
        <p>这是一个对话框内容</p>
      </CustomModal>
    </div>
  );
}

export default MyComponent;
  • 定义了名为 MyComponent 的函数组件,并接受一个名为 refreshKey 的属性,用来做外部的强制刷新。
  • 使用 useState 钩子创建了两个状态变量:isModalVisible(控制对话框的显示/隐藏)和 refresh(用于触发内部强制刷新)。
  • handleClick 函数在按钮点击时将 isModalVisible 设置为 true,显示对话框。
  • handleOkhandleCancel 函数分别用于确认和取消操作,将 isModalVisible 设置为 false,隐藏对话框。
  • refreshComponent 函数通过取反当前的 refresh 状态值来触发组件的重新渲染。
  • return 部分包含了 JSX 代码,其中:
    • <Tooltip> 组件用于添加提示文本,并嵌套了一个 <Button> 组件。
    • <CustomModal> 组件是自定义样式的对话框组件,传递了相关属性和事件处理程序。
    • <p> 标签是对话框的内容。

4. 使用示例

jsx 复制代码
import React, { useState } from 'react';
import MyComponent from './MyComponent';

function ParentComponent() {
  const [refreshKey, setRefreshKey] = useState(0);

  const handleRefresh = () => {
    setRefreshKey(prevKey => prevKey + 1);
  };

  return (
    <div>
      <button onClick={handleRefresh}>
        刷新子组件
      </button>

      <MyComponent refreshKey={refreshKey}>
    </MyComponent></div>
  );
}

export default ParentComponent;
相关推荐
@大迁世界8 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
千叶风行8 小时前
Text-to-SQL 技术设计与注意事项
前端·人工智能·后端
软件开发技术深度爱好者8 小时前
HTML5+JavaScript读取DOCX 文档完整内容
前端·html5
幽络源小助理9 小时前
苹果CMS V10 MXPro V4.5模版下载, 自适应视频主题源码, 幽络源源码
前端·开源·源码·php源码
kyriewen9 小时前
坏了,黑客学会用AI写外挂了
前端·程序员·ai编程
xiangxiongfly91510 小时前
Vue3 根据角色权限动态加载路由
前端·javascript·vue.js·动态加载路由
达达尼昂10 小时前
Claude 多 Agent 系统:从零搭建一个 4 Agent 团队
前端·架构·ai编程
费曼学习法11 小时前
React 18 并发模式(Concurrent Mode):Fiber 架构的终极进化
javascript·react.js
容智信息11 小时前
AI Agent(智能体)的输出格式应该从 Markdown 转向 HTML吗?
前端·人工智能·rust·编辑器·html·prompt
_风满楼11 小时前
TDD 进阶:换个角度看会议室预约
前端·javascript·github