🎉 Ant Design 6.0 来了!这一次它终于想通了什么?

大家好😁。

还记得我之前那篇吐槽《当 Ant Design 成了你最大的技术债》的文章吗😂?在那篇文章里,我痛斥了 Antd 的黑盒样式、难以覆盖的 !important 地狱,以及臃肿的 CSS-in-JS 运行时性能。

当时有很多朋友在评论区说:国内做 B 端,离不开它

前天,Ant Design 6.0 正式发布了。带着审视(甚至是一点点找茬🤔)的心态,我仔细翻阅了 Release Note 和源码。

看完之后,我沉默了片刻,然后想说一句: 这一次,Ant Design 好像真的听懂了我们的骂声。它正在试图撕掉笨重的标签,向现代前端开发范式(Tailwind、Headless)发起一次自我更新。

今天,我就以一个老用户的视角,来聊聊 Antd 6.0 到底改了什么,以及作为技术组长,我怎么看待这次升级🤷‍♂️。


告别运行时,拥抱 CSS Variables

在 v5 版本,Antd 引入了 CSS-in-JS。虽然它解决了按需加载的问题,但带来的运行时性能损耗和样式插入延迟,一直是性能敏感型项目的噩梦😭。

v6 做了一个极其正确的决定:默认采用纯 CSS Variables模式,并且支持零运行时(Zero Runtime)。

这意味着什么?

性能大翻身:浏览器原生支持 CSS 变量,不再需要 JS 去计算和插入样式。根据官方的对比图,Zero Runtime 模式下的性能表现是最佳的。这也意味着,我们那臃肿的 JS Bundle 终于可以瘦身了。

主题切换秒变:以前切换暗色模式,可能需要 JS 重新计算一堆 Token。现在?只需要改变根节点的几个 CSS 变量值,浏览器瞬间完成渲染。

拥抱 React 19:这次升级开启了 React Compiler 支持,并且彻底移除了对 React 16/17 的兼容代码,轻装上阵。

这才是 2025 年组件库该有的样子。CSS 的事情,就该让 CSS 去做,JS 别管太宽🤔。


全量组件语义化

这是我最兴奋的一点😁。

以前我们想改一个 Modal 的样式,得去浏览器里扒 ant-modal-contentant-modal-header 这种类名,然后写一堆高权重的 CSS 去覆盖。

v6 完成了所有组件的 DOM 语义化改造。

它引入了 classNamesstyles 属性(这就很有 Headless UI 的味道了🤔),允许你精准地把样式注入到组件的内部结构中。

比如,你想做一个俏皮风格的按钮,或者一个极客风的卡片,你不再需要写恶心的 CSS Selector,而是可以直接这样写:

jsx 复制代码
// 简直是 Tailwind 玩家的福音
<Button
  classNames={{
    root: 'rounded-tr-xl rounded-bl-xl', // 直接写 Tailwind 类名!
    icon: 'rotate-30',
  }}
  icon={<SmileOutlined />}
>
  Ant Design
</Button>

极客风卡片样式和效果

jsx 复制代码
<Card
  title="Hello World"
  classNames={{
    root: "bg-green-300/10 text-green-500 border-green-500 rounded-none [box-shadow:0_0_8px_theme(colors.green.500)]",
    header: "rounded-none border-green-500 [box-shadow:inset_0_0_8px_theme(colors.green.500)]",
    title:
      "text-green-500 [text-shadow:0_0_12px_theme(colors.green.400)] overflow-visible",
      body: "rounded-none [text-shadow:0_0_8px_theme(colors.green.400)] [box-shadow:inset_0_0_12px_theme(colors.green.500)]"
  }}
>
  Ant Design loves you!~ (=^・ω・^)
</Card>

Antd 终于意识到,它不能只做写死的积木,它得提供接口。这对于追求 UI 个性化的团队来说,绝对是史诗级利好👍👍👍。


IE 走好,不送

Antd 6.0 做了一个非常硬气的决定:彻底移除对 IE 的支持。

同时,React 的最低版本要求提升到了 React 18!

这可能对一些维护古董项目的团队是坏消息,但对于整个前端生态来说,这是大快人心的。我们终于不需要为了那 1% 的 IE 用户,去背负沉重的 polyfill 和 hack 代码了。


Ant Design X 2.0

除了一些基础库的升级,这次还有一个重磅消息:Ant Design X 2.0 同步发布

现在哪个 B 端产品不加点 AI 功能?Chat 界面、流式输出、提示词输入... 这些东西要是自己从头写,非常费劲。

Ant Design X 就是专门解决这个问题的。它不仅仅是 UI,更包含了一套面向 AI 场景的交互逻辑。

前端的战场正在从 CRUD 系统转向 AI 交互界面。Antd 这一步棋,走得很稳👍。


升级建议:要不要冲?🤔

作为技术组长,我不建议盲目升级,但我建议你认真评估

如果你是 v5 用户:直接冲! 官方承诺是平滑迁移,无需 codemod,直接升级即可。你能立刻获得性能提升和 CSS 变量的红利。

如果你是 v4 用户:v6 移除了 v4 的废弃 API。这依然是一次断崖式的升级,成本较高。建议先升级到 v5 过渡,或者在新项目中直接使用 v6。

如果你还在维护 IE 项目:留在 v5 吧,v5 进入了 1 年的维护周期,足够你养老了😖。


Ant Design 已经 10 岁了🫅。

在一个技术栈迭代快如闪电的时代,一个库能活 10 年,并且还能在第 10 年做出 v6 这样推倒重来式的革新,是值得赞扬的👍👍👍。

虽然我依然推崇 Tailwind + Headless UI 的灵活性,但 Ant Design 6.0 让我看到了重型组件库的另一种可能性------它在努力变轻,努力变开放,努力适应 AI 时代。

也许,它不再是我最大的技术债,而重新变成了那个可以信赖的老伙计😁。

你们怎么看这次 Antd 6.0 的升级?

相关推荐
yinuo1 天前
前端跨页面通讯终极指南⑥:SharedWorker 用法全解析
前端
PineappleCoder1 天前
还在重复下载资源?HTTP 缓存让二次访问 “零请求”,用户体验翻倍
前端·性能优化
拉不动的猪1 天前
webpack编译中为什么不建议load替换ast中节点删除consolg.log
前端·javascript·webpack
李姆斯1 天前
Agent时代下,ToB前端的UI和交互会往哪走?
前端·agent·交互设计
源码获取_wx:Fegn08951 天前
基于springboot + vue健身房管理系统
java·开发语言·前端·vue.js·spring boot·后端·spring
闲谈共视1 天前
基于去中心化社交与AI智能服务的Web钱包商业开发的可行性
前端·人工智能·去中心化·区块链
CreasyChan1 天前
C# 反射详解
开发语言·前端·windows·unity·c#·游戏开发
JIngJaneIL1 天前
基于Java+ vue智慧医药系统(源码+数据库+文档)
java·开发语言·前端·数据库·vue.js·spring boot
阿蒙Amon1 天前
JavaScript学习笔记:6.表达式和运算符
javascript·笔记·学习
hashiqimiya1 天前
两个步骤,打包war,tomcat使用war包
java·服务器·前端