码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 为React Ant-Design Table增加字段设置 | 京东云技术团队


    最近做的几个项目经常遇到这样的需求,要在表格上增加一个自定义表格字段设置的功能。就是用户可以自己控制那些列需要展示。

    在几个项目里都实现了一遍,每个项目的需求又都有点儿不一样,迭代了很多版,所以抽时间把这个功能封装了个组件:@silverage/table-custom,将这些差别都集成了进去,方便今后使用和维护。同时也方便需要这个功能的人来使用。

    下面介绍下安装和使用

    安装

    npm i @silverage/table-custom --save
    yarn add @silverage/table-custom
    pnpm add @silverage/table-custom
    
    
    • 1
    • 2
    • 3
    • 4

    组件在ant-design基础上开发,所以你也要安装antd。数据持久化使用的use-local-storage-state,也是要安装的。另外,react也是peer dependency。

    使用

    组件使用非常简单,只需要将你原先antd的

    换成即可。兼容所有antd table的属性。

    import { TableCustom } from '@silverage/table-custom'
    
    
    
    
    • 1
    • 2
    • 3
    • 4

    table-custom

    鼠标悬浮在表格时,表格右上角就会出现齿轮 图标。点击之后就可进入设置界面。通过勾选就可以隐藏/展示列。

    image.png

    支持单行表头,同时也支持双层合并表头。

    image.png

    你可能注意到上面截图中,ID列是灰色的,这是因为在使用时,业务希望某些列是固定展示不可隐藏的。这时可以通过对column设置disableCustom: true来实现。

    const columns = [
        {
            title: `ID`,
            dataIndex: `id`,
            key: `id`,
            width: 100,
            fixed: 'left',
            disableCustom: true // here
        }
    ]
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    另外,修改后的列想要保存,这里有两个方式:一种是通过localstorage做持久化,一种是通过后端提供接口。不同的项目选择不同方式实现,最近的几个项目两种都用了。

    localstorage的方式很简单,只需要提供组件storageKey属性即可。

    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    接口方式,可通过savedColumns和onChecklistChange配合实现。

    const [savedColumns, setSavedColumns] = useState([])
    
     {
            const res = await api.request()
            setSavedColumns(res?.data)
        }}
    />
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    过了一段时间使用后,在某些项目中,“极个别同志(no one but you)”认为,这个齿轮的图标太不明显了,想在表格上面放个按钮来控制,所以加了如下属性,让用户自己控制。因为原有表格上方可能有其他按钮。

    const [visible, setVisible] = useState(false)
    
     setVisible(false)} // and here
    />
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    又过了一段时间,为了今后必然出现的字段排序需求,又增加了排序功能,只需要设置sortable字段。

    
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    image.png

    鼠标拖拽字段后的icon就可以,同样支持单层和双层表头!

    也可以自定义icon样式:

    ::}
    />
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    查看完成文档:https://github.com/yuhongda/table-custom

    Enjoy

    作者:京东零售 于弘达

    来源:京东云开发者社区 自猿其说 Tech 转载请注明来源

  • 相关阅读:
    Spring - BeanDefinitionRegistryPostProcessor 扩展接口 动态注册bean
    RabbitMQ消息中间件
    基于DAP数仓建设过程说明
    Android12上修改erofs为ext4
    数据预处理方法
    图神经网络关系抽取论文阅读笔记(六)
    如何在Linux使用Docker部署Nexus容器并实现公网访问本地仓库【内网穿透】
    一个较通用的makefile解析
    python (语音)信号拆分为数据块,计算短期能量和过零率
    【C语言学习笔记---学指针必刷它】
  • 原文地址:https://blog.csdn.net/JDDTechTalk/article/details/134436584
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | Kerberos协议及其部分攻击手法
      0day的产生 | 不懂代码的"代码审计"
      安装scrcpy-client模块av模块异常,环境问题解决方案
      leetcode hot100【LeetCode 279. 完全平方数】java实现
      OpenWrt下安装Mosquitto
      AnatoMask论文汇总
      【AI日记】24.11.01 LangChain、openai api和github copilot
    • 热门文章
    • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
      奉劝各位学弟学妹们,该打造你的技术影响力了!
      五年了,我在 CSDN 的两个一百万。
      Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
      面试官都震惊,你这网络基础可以啊!
      你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
      心情不好的时候,用 Python 画棵樱花树送给自己吧
      通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
      13 万字 C 语言从入门到精通保姆级教程2021 年版
      10行代码集2000张美女图,Python爬虫120例,再上征途
    Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
    正则表达式工具 cron表达式工具 密码生成工具

    京公网安备 11010502049817号