前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Mock21-接口数据管理实现

Mock21-接口数据管理实现

作者头像
MegaQi
发布2024-08-29 17:56:11
900
发布2024-08-29 17:56:11
举报
文章被收录于专栏:非典型性程序员

在最初的几篇讲页面实现的时候关于接口管理实现,只是在数据库造了些数据用于查询展示。其中用了antd的高级组件protable,本篇我们在使用高级系列组件中的 ProForm +抽屉(Drawer)弹窗的方式来快速实现接口增改操作。

关于ProFrom高级表单一段官方说明

https://procomponents.ant.design/components/form

与其配合还有一系列封装子组件 ProFormFields 表单项

https://procomponents.ant.design/components/field-set

回到功能本功能实现上

  1. protable 通过 toolBarRender 增加自定义按钮
代码语言:javascript
复制
toolBarRender={() => [
    <Button
        key="addInterface"
        icon={<PlusOutlined />}
        onClick={() => {
        setApiRecord({})
        setApiAction("ADD")
        setApiVisible(true)
        }}
        type="primary"
    >
        添加接口
    </Button>,
 ]}
  1. 在columns定义的操作列增加修改菜单
代码语言:javascript
复制
render: (text, record) => (
        <Space>
          <a >规则配置</a>
          <a onClick={() => {
            setApiRecord(record)
            setApiAction("EDIT")
            setApiVisible(true)
          }}>修改接口</a>
        </Space>
      ),

这两个关键部分代码中都展示 setApiRecord,setApiAction,setApiVisible为标记和抽屉显隐控制。

因表单项很多,同样根据之前的学习的自定义Component实现一个自定义独立组件

截图只展示了表单部分代码,全部的实现代码直接参考本项目源码 chapter21 分支代码

前后端伪代码的逻辑

  1. 实现新增和修改的统一接口,保存数据通过是否有ID判断是insert还是update;
  2. 前端点击新增或修改做对应的动作标记和抽屉表单显示,其中如果是修改要将所在行数据放到定义的变量中,如果是新增则至为空;
  3. 抽屉表单中非修改属性要根据动作显示隐藏或不可编辑;
  4. ProFormDrawerForm都有默认提交按钮,此处选择了后者,个人实现中根据设计规范可自行选择保留其一;
  5. 注意之前篇章中升级过antd,所以新的js接口统一放到\services\ant-design-pro实现,不在放在page下;
  6. DrawerFormonFinish 实现前后端接口操作。
  7. 保存成功操作后要关闭抽屉,并通过上级refTable刷新列表

最终本篇实现的功能效果如GIF

本篇实现的代码已经在开源代码项目上创建chapter20分支,大家可以下载分支参考实现此部分代码。

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2024-08-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 非典型性程序员 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档