最新要闻
- 一台无人机能替代20名劳动力,江陵县无人机植保为粮食生产提质增效
- 李楠称中国手机厂商内战内行愚蠢可笑 支持比亚迪主张
- 科大讯飞净利润同比下降73.54% 回应:钱砸进AI大模型了
- 荣耀宣布全国范围开通地震预警:烈度高于2.0将弹窗预警
- 江苏盐城胃肠病医院哪个好
- 宝马3系遭车主集体投诉:新车就传动轴异响 售后让换轴
- 搬家神器!长城哈弗猛龙更多信息曝光:后备箱最大空间1404升
- 单风扇极简风!七彩虹iGame RTX 4060 Ti Mini OC 8GB显卡图赏
- 男子背140斤冰柜峨眉山顶卖水 网友感慨:6块一瓶真不贵
- 一起掀桌子!最高下调6万元:11天内十品牌“官降”
- “操心”变“暖心” 这个暑期托管班让职工很“省心”
- 永别了 Intel迷你机!三款NUC被正式终结
- 钢铁侠座驾成绝唱!奥迪R8彻底无了:第一代设计师亲手“送别”
- 五菱推出“移动充电宝”:具备L4级自动驾驶 手机下单就能上门充电
- 日本北海道附近海域发生6.0级地震:震源深度50公里
- 杭州女生参加比赛获奖百万:哭着感谢张大大
广告
手机
![顺络电子:董事长部分股权办理股票质押业务](http://www.viltd.com/uploadfile/2022/0610/20220610103218963.jpg)
顺络电子:董事长部分股权办理股票质押业务
![深圳7月二手住宅成交2259套,中介称近期咨询客户开始增加](http://www.viltd.com/uploadfile/2022/0610/20220610103218963.jpg)
深圳7月二手住宅成交2259套,中介称近期咨询客户开始增加
- 顺络电子:董事长部分股权办理股票质押业务
- 深圳7月二手住宅成交2259套,中介称近期咨询客户开始增加
- 最新洪水形势如何?时隔多年为何又见洪水?解答来了!
- 李明俊在调研白龟湖科创新城和环湖路建设工作时强调 勇于担当负责 善于创新突破 着力打造群众满意的放心工程
- 遮天:东荒两大家族登场,庞博成为妖王,妖族公主颜如玉绝美登场
- 京运通: 我司自扩产硅片业务以来,所有单晶炉均为自供
家电
Ant Design Pro项目ProTable怎么实现单元格合并效果
(资料图片仅供参考)
前情
公司有经常需要做一些后台管理页面,我们选择了Ant Design Pro,它是基于 Ant Design 和 umi 的封装的一整套企业级中后台前端/设计解决方案。
产品效果图
最新接到的一个后台管理界面需求,需要根据相同的itemId做单元格合并,要实现的效果如下:
解决方案
方式1:使用表格的rowspan属性来实现单元格合并
关键示例代码:
/** * 实现单元格合并 * 在原始数据中加上rowSpan属性,该值为接下来和当前项itemId相同的个数+1, * 其它相同的项rowSpan设为0即为不显示 * @param list */const dataProcessingForRowspan = (list, key) => { let repeatCount = 1; let startIndex = 0; list.forEach((item, index) => { if (index < list.length - 1 && item.itemId === list[index+1].itemId) { item.rowSpan = 0; repeatCount += 1 } else { list[startIndex].rowSpan = repeatCount; startIndex = index + 1; repeatCount = 1; } })}const columns: ProColumns[] = [ { title: "商品itemId", dataIndex: "itemId", editable: false, render: (text: any, record: any, index: number) => { return { children: text || "", props: { rowSpan: record.rowSpan ? record.rowSpan : 0 } } } },... { title: "操作", dataIndex: "option", valueType: "option", render: (text, record:any, index) => { return { children: [ { }} > 拉取sku , " | " , { }} > 删除 , ], props: { rowSpan: record.rowSpan ? record.rowSpan : 0 } } }, }, ];return ( headerTitle="" rowKey="skuId" search={{ labelWidth: 120, }} toolBarRender={() => [ ]} request={async (params) => { await waitTime(3000)// 这里是模拟的数据 const initData = [{ itemId: "1", name: "魅族20", skuId: "a123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 3, estimatedDeduction: 49.18 },{ itemId: "1", name: "魅族20", skuId: "b123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 2, estimatedDeduction: 49.18 },{ itemId: "2", name: "魅族20", skuId: "c123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 },{ itemId: "2", name: "魅族20", skuId: "d123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 },{ itemId: "2", name: "魅族20", skuId: "e123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 },{ itemId: "3", name: "魅族20", skuId: "f123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 }] dataProcessingForRowspan(initData, "itemId"); return { data: initData, // success 请返回 true, // 不然 table 会停止解析数据,即使有数据 success: true, // 不传会使用 data 的长度,如果是分页一定要传 total: 5, }; }} columns={columns} /> );
方式2:直接自定义reander方法,在一个单元格中生成遍历的内容,内容块之间加下边框,实现伪单元格合并效果
关键示例代码:
const columns: ProColumns[] = [ { title: "商品itemId", dataIndex: "itemId", editable: false, }, { title: "商品名", dataIndex: "itemName", }, { title: "skuId", dataIndex: "itemSkuList", key: "skuId", render: (text: any, record: any) => { return record.itemSkuList.map((item: any, indexIn: number) => { return ( {item["skuId"]} ); }); }, }, ... { title: "预估抵扣", dataIndex: "itemSkuList", key: "predictDeductionPrice", editable: false, hideInSearch: true, render: (text: any, record: any) => { return record.itemSkuList.map((item: any, indexIn: number) => { return ( {item["predictDeductionPrice"]} ); }); }, }, { title: "操作", dataIndex: "option", valueType: "option", render: (text: any, record: any) => { return ( <> { }} > 拉取sku {" "} |{" "} { }} > 删除 > ); }, }, ]; return ( headerTitle="" rowKey="itemId" search={{ labelWidth: 120, }} toolBarRender={() => [ ]} request={async (params) => { await waitTime(3000) const initData = [{ itemId: "1", itemSkuList:[ { name: "魅族20", skuId: "a123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 3, estimatedDeduction: 49.18 },{ name: "魅族20", skuId: "b123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 2, estimatedDeduction: 49.18 },{ name: "魅族20", skuId: "c123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 },{ } ] },{ itemId: "2", itemSkuList: [ { name: "魅族20", skuId: "d123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 },{ name: "魅族20", skuId: "e123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 } ] },{ itemId: "3", name: "魅族20", skuId: "f123456b", productAbbreviation: "魅族20 独白 8GB+256GB 全网通公开版", price: 2459, maximumDeduction: 1, estimatedDeduction: 49.18 }] dataProcessingForRowspan(initData, "itemId"); return { data: initData, // success 请返回 true, // 不然 table 会停止解析数据,即使有数据 success: true, // 不传会使用 data 的长度,如果是分页一定要传 total: 5, }; }} columns={columns} /> );
- 注:二种方式是对不同的数据结构做的更优的方法,如果只想用其中一种,二种数据结构互转一下也可以的。
关键词:
-
-
-
-
Ant Design Pro项目ProTable怎么实现单元格合并效果
【新华解读】社融数据引发降准预期“拉满” 债市能否迎来新一轮牛市?
一台无人机能替代20名劳动力,江陵县无人机植保为粮食生产提质增效
李楠称中国手机厂商内战内行愚蠢可笑 支持比亚迪主张
科大讯飞净利润同比下降73.54% 回应:钱砸进AI大模型了
荣耀宣布全国范围开通地震预警:烈度高于2.0将弹窗预警
江苏盐城胃肠病医院哪个好
宝马3系遭车主集体投诉:新车就传动轴异响 售后让换轴
搬家神器!长城哈弗猛龙更多信息曝光:后备箱最大空间1404升
单风扇极简风!七彩虹iGame RTX 4060 Ti Mini OC 8GB显卡图赏
男子背140斤冰柜峨眉山顶卖水 网友感慨:6块一瓶真不贵
一起掀桌子!最高下调6万元:11天内十品牌“官降”
“操心”变“暖心” 这个暑期托管班让职工很“省心”
面对AI冲击,技术人才该如何考核?
永别了 Intel迷你机!三款NUC被正式终结
钢铁侠座驾成绝唱!奥迪R8彻底无了:第一代设计师亲手“送别”
五菱推出“移动充电宝”:具备L4级自动驾驶 手机下单就能上门充电
日本北海道附近海域发生6.0级地震:震源深度50公里
杭州女生参加比赛获奖百万:哭着感谢张大大
特效行,剧情人物逻辑跟子供向一样
苹果账号被禁用怎么办?
恭喜又一白鲸开源成员成为 Apache SeaTunnel PMC Member
用python用户注册和短信验证码逻辑实现案例
闻汛而动、暖心安置、合力重建——黑龙江全力打赢防汛救灾“遭遇战”“主动仗”
【财经分析】MSCI中国季度调整新增29只剔除19只 关注对部分个股潜在冲击
4连板塞力医疗:近三年公司主营业务综合毛利率总体呈缓慢下降趋势
一点链接就盗取你的资金?安全大V科普:技术是有的 但别担心
净利润率15%!华为上半年营收出炉:销售收入3109亿 整体稳健
有望搭载自动充气系统 特斯拉皮卡超大“怪物车轮”曝光
挑战ARM!高通恩智浦等5家巨头联手组建新公司 专搞RISC-V
比OLED更完美!苹果未来将在iPhone上使用MicroLED屏
观看曹文轩《草房子》的观后感800字
【金融街发布】证监会同意上海出口集装箱结算运价指数(欧洲航线)期货注册并确定为境内特定品种
【金融街发布】人民银行:前七个月社会融资规模增量累计为22.08万亿元
五烈镇成立困难家庭青少年助学资金会
全球首款ChatGPT音箱来了:搭载双AI 可创作诗歌
小米13 Ultra同款基材!Redmi K60至尊版搭载华星C7屏
福特首款纯电正式败走中国:血降10万清库存、连官博都要关停了
iOS 17对比鸿蒙4:谁是更智慧的手机系统?
橙色还带猫的主板没见过吧?七彩虹带来COLORFIRE B760 MEOW橘影橙
香港长实楼盘亲海駅II推售即掀起收票潮,共收逾3.8万票史上称王
萌火了!《三孩来了》缓解生育焦虑,为提升生育意愿注入新动能
苹果手伸太长车企不干了?通用汽车:逐步淘汰CarPlay
《仙剑奇侠传四》重制版制作人张孝全发布说明:不会放弃游戏开发
小米大语言模型MiLM-6B首次现身!同参数量级排名第一
超乎预期!Redmi K60至尊版支持IP68:米粉集体感到意外
首车硬派越野!比亚迪方程豹品牌暨技术发布会定档8月16日
GaussDB(DWS)函数不同写法引发的结果差异
未来世界的数字幻境:VR 科技的崭新篇章
外企持续加码,中国引资磁力不减
迷你身材 好吃小巧!和路雪可爱多冰激凌大促:一支到手1.14元
《原子之心》DLC IGN6分:能看到冰箱诺拉还不错
100%当季采摘 洽洽每日坚果89元1.5斤官方大促
小米平板6 Max绝配!小米智能触控键盘来了 米粉:这就是个笔记本
印度被截胡!时隔近半个世纪后:俄罗斯将重返月球
上海警方破获油卡诈骗案:骗子骗取预付款,20余名司机受骗30余万元
PC需求回升:英特尔处理器销量增加 AMD遇阻、台式机显卡越来越少人买
数度哽咽 王传福首次展示脆弱 比亚迪终成一哥
通用汽车遭遇电池供应危机 CFO:承认电车产量难以提升
QLC闪存立功 三星公开256TB SSD硬盘:1000TB也不远了
500万元!重庆丰华股份收到迁入注册地政府补助
四川李家沟北锂矿勘查权限时竞价落锤10.1亿元 较起拍价升值1771倍
iPhone 15最受期待的五大升级!网友:花更多钱也得买高配版
理想称30-50万主流SUV只有自家配空悬+CDC!智己汽车不服:在线回怼
左眼跳财不靠谱!女子眼皮跳了半年多竟是眼睑痉挛
国产OLED份额首破40% 韩国又一个垄断性优势产业岌岌可危:京东方追赶三星
首发2699元 米家空调巨省电2匹发布:高效低噪风道
近5个交易日46家公司获机构调研 宏发股份最受关注
169元 联想小新105W三口氮化镓适配器开售:3设备同时充
国内需求复苏 中芯国际40nm、28nm工艺已满载:供应链正在洗牌
“怀孕后腋下变黑生儿子”是真的吗?
宁德时代进军二手车业务?已为二手车检测平台查博士最大股东
别慌!国内油价下一轮只是小涨 预计上调0.10元/升
上海立达学院继续教育学院航空空乘招生是统招吗?
聊聊语言模型与知识图谱
监控keepalived_vip控制容器的状态
限时8折!《30XX》游戏支持中文 中文界面好评
福特中国大召回:超7万辆车有起火风险
买1得12:京东+腾讯视频等12项联合会员限时238元(价值1425元)
售27980元 春风新车450CL-C摩托上市:外挂“声浪放大器”
福耀大学将完工!曹德旺捐款100亿成理事长:赚很多钱还给社会 每个学生补贴5万
雷军揭秘年度演讲重磅内容:当年一个决定改变了一生
大豪科技8月11日快速反弹
未来几天“热”力十足,注意防暑降温
《C++ GUI Qt4编程》第2章——创建对话框——深入介绍信号和槽
资源过滤器—MVC中使用资源过滤器实现不执行Action方法体读取缓存信息返回
公安部提醒:有效保护个人信息 做到“三个不”
长城汽车CTO:中国汽车怎么在一起?还是先打一架吧
俄罗斯“月球-25”号发射全程视频公布:预计8月21日着陆 比印度早两天
CPU开销骤降95%!Edge团队宣布改进网页Office应用
主打“硬派+智能” 2024款坦克300上市 售19.98万起
贴脸特斯拉Model Y 开打价格战!极氪001最高降价3.7万元
内蒙古兴安盟那达慕开幕 20余万中外游客感受草原文化
厄瓜多尔总统宣布全国进入紧急状态大选如期举行
全球首个商用核电小堆核心模块“玲龙之心”吊装成功:全球领先
你贡献没?月赚40万 BBA人争相入职!蔚来销售回应高薪 是很高、但太夸张
镉怎么读 镝怎么读
上半年地方财政收入同比增长 中西部省份增速领先
魅族20/20 PRO正式升级Flyme 10.2稳定版!手机、车机合二为一
经典IP动画《忍者神龟:变种大乱斗》今日上映:成龙配音神龟师傅