手写antd的Row组件和Col组件

背景

为什么要自己手写antd的Row组件和Col组件呢?

很简单,就是因为设计稿要求表单内一行五个FormItem,并且这几个FormItem随着屏幕尺寸自适应。但是antd的栅格化系统是按照24等分来的,最关键的是antd中的Col组件的span不支持小数,而需求的一行5个,24/5 = 4.8,是不支持的,所以只能自己手写了

实现这个需求实际上有两个方式

  • 不封装纯css实现
  • 封装组件

这里主要表现的是第二种封装组件的形式

实现思路

手写MyRowMyCol

MyRow组件接收gutterchildren作为props。gutter用于定义列与列之间的间隔,children则是要渲染在行内的内容。

MyCol组件接收decimalSpan, children, gutter, flex, style, 和 className作为props:

  • decimalSpan是一个可选的数字,表示占用的网格列数的百分比(相对于24列的总宽度)。如果提供,它将计算为占总宽度的百分比,并用于设置列的宽度。
  • gutter定义了列之间的间隔。
  • flex是一个可选的属性,用于设置列的弹性布局。如果是数字,将会被转换成百分比形式的flex值;如果是字符串,则直接使用。
  • style是一个可选的CSS属性对象,可以覆盖或添加自定义样式。
  • className是一个可选的字符串,用于应用CSS类。

实现方式

MyRow只是简单地将props传递给Ant Design的Row组件。

MyCol则更加复杂一些,它首先计算spanWidth的值,如果decimalSpan被提供,spanWidth将是列宽度的百分比;否则,它是0。然后,如果flex被提供,会创建一个flexStyle对象,其中包含适当的flex属性。这些样式(包括从style prop传入的任何附加样式)都会被应用到一个div元素上,而不是Ant Design的Col

下面就是整个组件的代码,ts+hook

typescript 复制代码
import { Row } from 'antd';
import React from 'react';
import type { Gutter } from 'antd/es/grid/row';

export const MyRow = ({
  gutter,
  children,
}: {
  gutter: Gutter | [Gutter, Gutter];
  children: React.ReactNode;
}) => <Row gutter={gutter}>{children}</Row>;

export const MyCol = ({
  decimalSpan,
  children,
  gutter,
  flex,
  style ={},
  className,
}: {
  decimalSpan?: number;
  children: React.ReactNode;
  gutter: number
  flex?: number | string;
  style?:React.CSSProperties
  className?:string
}) => {

    // 如果提供了span属性,计算宽度的百分比
    const spanWidth = decimalSpan ? `${(decimalSpan / 24) * 100}%` : 0;

    // 如果提供了flex属性,根据flex值设置弹性布局
    const flexStyle = flex ? { flex: typeof flex === 'number' ? `0 0 ${flex}%` : flex } : {};
  
    const colStyle = {
      paddingLeft: gutter / 2,
      paddingRight: gutter / 2,
      width: spanWidth, // 如果flex属性存在,spanWidth将会被flex样式覆盖
      ...flexStyle,
      ...style,
    };
  return <div className={className} style={colStyle}>{children}</div>;
};
相关推荐
小兵阿飞1 分钟前
Vite 技术介绍:实现原理、应用与优化
前端·vite
jiayong2312 分钟前
第 13 课:分页、页码状态和 URL 同步
开发语言·前端·javascript·vue.js·学习
smilejingwei39 分钟前
用 AI 编程生成 ECharts 图表并嵌入报表的实践
前端·人工智能·echarts·bi·报表工具·商业智能
Linux运维技术栈1 小时前
Cloudflare Argo Smart Routing全球加速:优化跨境回源链路,提升跨区域访问体验
大数据·前端·数据库
恋猫de小郭2 小时前
Android CLI ,谷歌为 Android 开发者专研的 AI Agent,提速三倍
android·前端·flutter
freewlt2 小时前
从 0 搭建现代前端组件库:2026年完整实战指南
前端
凌冰_2 小时前
Thymeleaf 核心语法详解
java·前端·javascript
AIBox3652 小时前
claude 镜像 api 使用指南(2026 年4 月更新)
java·服务器·前端·人工智能·gpt·前端框架
SuperEugene2 小时前
Vue3 配置文件管理:按模块拆分配置,提升配置可维护性|配置驱动开发实战篇
前端·javascript·vue.js·驱动开发
阿凤212 小时前
后端返回文件二进制流
开发语言·前端·javascript·uniapp