2022-08-31 17:41:47 +08:00
|
|
|
|
---
|
2023-08-04 19:27:38 +08:00
|
|
|
|
group:
|
|
|
|
|
title: 迁移
|
|
|
|
|
order: 2
|
|
|
|
|
order: 0
|
2022-08-31 17:41:47 +08:00
|
|
|
|
title: 从 v4 到 v5
|
2023-08-07 19:35:32 +08:00
|
|
|
|
tag: Updated
|
2022-08-31 17:41:47 +08:00
|
|
|
|
---
|
|
|
|
|
|
2022-11-29 18:05:40 +08:00
|
|
|
|
本文档将帮助你从 antd `4.x` 版本升级到 antd `5.x` 版本,如果你是 `3.x` 或者更老的版本,请先参考之前的[升级文档](https://4x.ant.design/docs/react/migration-v4-cn)升级到 4.x。
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
|
|
|
|
## 升级准备
|
|
|
|
|
|
|
|
|
|
1. 请先升级到 4.x 的最新版本,按照控制台 warning 信息移除/修改相关的 API。
|
|
|
|
|
|
|
|
|
|
## 5.0 有哪些不兼容的变化
|
|
|
|
|
|
|
|
|
|
### 设计规范调整
|
|
|
|
|
|
|
|
|
|
- 基础圆角调整,由统一的 `2px` 改为四级圆角,分别为 `2px` `4px` `6px` `8px`,分别应用于不同场景,比如默认尺寸的 Button 的圆角调整为了 `6px`。
|
2023-09-20 16:59:56 +08:00
|
|
|
|
- 主色调整,由 `#1890ff` 改为 `#1677ff`。
|
2022-08-31 17:41:47 +08:00
|
|
|
|
- 整体阴影调整,由原本的三级阴影调整为两级,分别用于常驻页面的组件(如 Card)和交互反馈(如 Dropdown)。
|
|
|
|
|
- 部分组件内间距调整。
|
|
|
|
|
- 整体去线框化。
|
|
|
|
|
|
|
|
|
|
### 技术调整
|
|
|
|
|
|
|
|
|
|
- 弃用 less,采用 CSS-in-JS,更好地支持动态主题。底层使用 [@ant-design/cssinjs](https://github.com/ant-design/cssinjs) 作为解决方案。
|
|
|
|
|
- 所有 less 文件全部移除,less 变量不再支持透出。
|
|
|
|
|
- 产物中不再包含 css 文件。由于 CSS-in-JS 支持按需引入,原本的 `antd/dist/antd.css` 也已经移除,如果需要重置一些基本样式请引入 `antd/dist/reset.css`。
|
2023-02-27 10:13:41 +08:00
|
|
|
|
- 如果需要组件重置样式,又不想引入 `antd/dist/reset.css` 从而导致污染全局样式的话,可以尝试在应用最外层使用[App 组件](/components/app-cn),解决原生元素没有 antd 规范样式的问题。
|
2022-08-31 17:41:47 +08:00
|
|
|
|
- 移除 css variables 以及在此之上构筑的动态主题方案。
|
2022-12-09 15:04:08 +08:00
|
|
|
|
- LocaleProvider 在 4.x 中已经废弃(使用 `<ConfigProvider locale />` 替代),我们在 5.x 里彻底移除了相关目录 `antd/es/locale-provider`、`antd/lib/locale-provider`。
|
2022-10-17 16:40:46 +08:00
|
|
|
|
- 内置的时间库使用 Dayjs 替代 Moment.js,具体请查看 [使用自定义日期库](/docs/react/use-custom-date-library-cn/)。
|
2022-11-21 22:33:47 +08:00
|
|
|
|
- 不再支持 `babel-plugin-import`,CSS-in-JS 本身具有按需加载的能力,不再需要插件支持。
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
|
|
|
|
### 兼容性调整
|
|
|
|
|
|
|
|
|
|
- 不再支持 IE 浏览器。
|
|
|
|
|
|
|
|
|
|
#### 组件 API 调整
|
|
|
|
|
|
|
|
|
|
- 组件弹框的 classname API 统一为 `popupClassName`,`dropdownClassName` 等类似 API 都会被替换。
|
2022-11-18 13:05:14 +08:00
|
|
|
|
|
2022-08-31 17:41:47 +08:00
|
|
|
|
- AutoComplete 组件
|
|
|
|
|
- Cascader 组件
|
|
|
|
|
- Select 组件
|
|
|
|
|
- TreeSelect 组件
|
|
|
|
|
- TimePicker 组件
|
|
|
|
|
- DatePicker 组件
|
2022-09-01 09:51:11 +08:00
|
|
|
|
- Mentions 组件
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
```diff
|
|
|
|
|
import { Select } from 'antd';
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
const App: React.FC = () => (
|
|
|
|
|
<Select
|
|
|
|
|
- dropdownClassName="my-select-popup"
|
|
|
|
|
+ popupClassName="my-select-popup"
|
|
|
|
|
/>
|
|
|
|
|
);
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
export default App;
|
|
|
|
|
```
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
|
|
|
|
- 组件弹框的受控可见 API 统一为 `open`,`visible` 等类似 API 都会被替换。
|
2022-11-18 13:05:14 +08:00
|
|
|
|
|
2022-08-31 17:41:47 +08:00
|
|
|
|
- Drawer 组件 `visible` 变为 `open`。
|
|
|
|
|
- Modal 组件 `visible` 变为 `open`。
|
|
|
|
|
- Dropdown 组件 `visible` 变为 `open`。
|
|
|
|
|
- Tooltip 组件 `visible` 变为 `open`。
|
|
|
|
|
- Tag 组件 `visible` 已移除。
|
|
|
|
|
- Slider 组件 `tooltip` 相关 API 收敛到 `tooltip` 属性中。
|
|
|
|
|
- Table 组件 `filterDropdownVisible` 变为 `filterDropdownOpen`。
|
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
```diff
|
|
|
|
|
import { Modal, Tag, Table, Slider } from 'antd';
|
|
|
|
|
|
|
|
|
|
const App: React.FC = () => {
|
|
|
|
|
const [visible, setVisible] = useState(true);
|
|
|
|
|
|
|
|
|
|
return (
|
|
|
|
|
<>
|
|
|
|
|
- <Modal visible={visible}>content</Modal>
|
|
|
|
|
+ <Modal open={visible}>content</Modal>
|
|
|
|
|
|
|
|
|
|
- <Tag visible={visible}>tag</Tag>
|
|
|
|
|
+ {visible && <Tag>tag</Tag>}
|
|
|
|
|
|
|
|
|
|
<Table
|
|
|
|
|
data={[]}
|
|
|
|
|
columns={[
|
|
|
|
|
{
|
|
|
|
|
title: 'Name',
|
|
|
|
|
dataIndex: 'name',
|
|
|
|
|
- filterDropdownVisible: visible,
|
|
|
|
|
+ filterDropdownOpen: visible,
|
|
|
|
|
}
|
|
|
|
|
]}
|
|
|
|
|
/>
|
|
|
|
|
|
|
|
|
|
- <Slider tooltipVisible={visible} />
|
|
|
|
|
+ <Slider tooltip={{ open: visible }} />
|
|
|
|
|
</>
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export default App;
|
|
|
|
|
```
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
|
|
|
|
- `getPopupContainer`: 所有的 `getPopupContainer` 都需要保证返回的是唯一的 div。React 18 concurrent 下会反复调用该方法。
|
2022-11-18 13:05:14 +08:00
|
|
|
|
- Upload List dom 结构变化。[#34528](https://github.com/ant-design/ant-design/pull/34528)
|
2022-08-31 17:41:47 +08:00
|
|
|
|
- Notification
|
2022-11-18 13:42:10 +08:00
|
|
|
|
- 静态方法不再允许在 `open` 中动态设置 `prefixCls` `maxCount` `top` `bottom` `getContainer`,Notification 静态方法现在将只有一个实例。如果需要不同配置,请使用 `useNotification`。
|
2022-11-18 13:05:14 +08:00
|
|
|
|
- `close` 改名为 `destroy`,和 message 保持一致。
|
|
|
|
|
- Drawer `style` 和 `className` 迁移至 Drawer 弹层区域上,原属性替换为 `rootClassName` 和 `rootStyle`。
|
2022-11-29 22:57:36 +08:00
|
|
|
|
- 4.x 中已经废弃的 `message.warn` 现在被彻底移除,请使用 `message.warning` 代替。
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
|
|
|
|
#### 组件重构与移除
|
|
|
|
|
|
2023-03-21 13:08:43 +08:00
|
|
|
|
- 移除 `locale-provider` 目录。`LocaleProvider` 在 v4 中已移除,请使用 `ConfigProvider` 替代。
|
2022-11-17 21:48:03 +08:00
|
|
|
|
- 移除 Comment 组件,移至 `@ant-design/compatible` 中维护。
|
|
|
|
|
- 移除 PageHeader 组件,移至 `@ant-design/pro-components` 中维护。
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
```diff
|
2023-01-01 13:41:39 +08:00
|
|
|
|
- import { PageHeader, Comment } from 'antd';
|
2022-11-18 13:05:14 +08:00
|
|
|
|
+ import { Comment } from '@ant-design/compatible';
|
|
|
|
|
+ import { PageHeader } from '@ant-design/pro-layout';
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
const App: React.FC = () => (
|
|
|
|
|
<>
|
|
|
|
|
<PageHeader />
|
|
|
|
|
<Comment />
|
|
|
|
|
</>
|
|
|
|
|
);
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
export default App;
|
|
|
|
|
```
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-09-27 16:56:56 +08:00
|
|
|
|
- BackTop 组件在 `5.0.0` 中废弃,移至 FloatButton 悬浮按钮中。如需使用,可以从 FloatButton 中引入。
|
2022-09-26 09:54:27 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
```diff
|
|
|
|
|
- import { BackTop } from 'antd';
|
|
|
|
|
+ import { FloatButton } from 'antd';
|
2022-09-26 09:54:27 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
const App: React.FC = () => (
|
|
|
|
|
<>
|
|
|
|
|
- <BackTop />
|
|
|
|
|
+ <FloatButton.BackTop />
|
|
|
|
|
</>
|
|
|
|
|
);
|
2022-09-26 09:54:27 +08:00
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
export default App;
|
|
|
|
|
```
|
2022-09-26 09:54:27 +08:00
|
|
|
|
|
2022-08-31 17:41:47 +08:00
|
|
|
|
## 开始升级
|
|
|
|
|
|
2022-11-17 21:48:03 +08:00
|
|
|
|
通过 git 保存你的代码,然后按照上述文档进行依赖安装:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npm install --save antd@5.x
|
|
|
|
|
```
|
|
|
|
|
|
2022-12-12 11:49:29 +08:00
|
|
|
|
如果你需要使用 v4 废弃组件如 `Comment`、`PageHeader`,请安装 `@ant-design/compatible` 与 `@ant-design/pro-layout` 做兼容:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npm install --save @ant-design/compatible@v5-compatible-v4
|
|
|
|
|
npm install --save @ant-design/pro-layout
|
|
|
|
|
```
|
|
|
|
|
|
2022-12-07 11:39:03 +08:00
|
|
|
|
你可以手动对照上面的列表逐条检查代码进行修改,另外,我们也提供了一个 codemod cli 工具 [@ant-design/codemod-v5](https://github.com/ant-design/codemod-v5) 以帮助你快速升级到 v5 版本。
|
|
|
|
|
|
|
|
|
|
在运行 codemod cli 前,请先提交你的本地代码修改。
|
|
|
|
|
|
|
|
|
|
```shell
|
|
|
|
|
# 使用 npx 直接运行
|
|
|
|
|
npx -p @ant-design/codemod-v5 antd5-codemod src
|
|
|
|
|
|
|
|
|
|
# 或者使用 pnpm 直接运行
|
|
|
|
|
pnpm --package=@ant-design/codemod-v5 dlx antd5-codemod src
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
<video autoplay="" loop="" style="width: 100%; max-height: 600px; object-fit: contain;">
|
|
|
|
|
<source src="https://mdn.alipayobjects.com/huamei_7uahnr/afts/file/A*Sjy5ToW6ow0AAAAAAAAAAAAADrJ8AQ" type="video/webm">
|
|
|
|
|
<source src="https://mdn.alipayobjects.com/huamei_7uahnr/afts/file/A*hTDYQJ2HFTYAAAAAAAAAAAAADrJ8AQ" type="video/mp4">
|
|
|
|
|
</video>
|
|
|
|
|
|
|
|
|
|
> 注意 codemod 不能涵盖所有场景,建议还是要按不兼容的变化逐条排查。
|
|
|
|
|
|
2022-11-21 22:33:47 +08:00
|
|
|
|
### less 迁移
|
|
|
|
|
|
2022-11-17 21:48:03 +08:00
|
|
|
|
如果你使用到了 antd 的 less 变量,通过兼容包将 v5 变量转译成 v4 版本,并通过 less-loader 注入:
|
|
|
|
|
|
2022-11-23 10:26:44 +08:00
|
|
|
|
```js
|
|
|
|
|
const { theme } = require('antd/lib');
|
|
|
|
|
const { convertLegacyToken } = require('@ant-design/compatible/lib');
|
2022-11-17 21:48:03 +08:00
|
|
|
|
|
|
|
|
|
const { defaultAlgorithm, defaultSeed } = theme;
|
|
|
|
|
|
|
|
|
|
const mapToken = defaultAlgorithm(defaultSeed);
|
|
|
|
|
const v4Token = convertLegacyToken(mapToken);
|
|
|
|
|
|
|
|
|
|
// Webpack Config
|
2023-01-11 16:48:09 +08:00
|
|
|
|
module.exports = {
|
|
|
|
|
// ... other config
|
|
|
|
|
loader: 'less-loader',
|
2022-11-17 21:48:03 +08:00
|
|
|
|
options: {
|
|
|
|
|
lessOptions: {
|
|
|
|
|
modifyVars: v4Token,
|
|
|
|
|
},
|
|
|
|
|
},
|
2023-01-11 16:48:09 +08:00
|
|
|
|
};
|
2022-11-17 21:48:03 +08:00
|
|
|
|
```
|
2022-08-31 17:41:47 +08:00
|
|
|
|
|
2022-12-09 11:41:50 +08:00
|
|
|
|
同时移除对 antd less 文件的直接引用:
|
|
|
|
|
|
|
|
|
|
```diff
|
|
|
|
|
// Your less file
|
|
|
|
|
-- @import (reference) '~antd/es/style/themes/index';
|
|
|
|
|
or
|
|
|
|
|
-- @import '~antd/es/style/some-other-less-file-ref';
|
|
|
|
|
```
|
|
|
|
|
|
2022-11-21 22:33:47 +08:00
|
|
|
|
### 移除 babel-plugin-import
|
|
|
|
|
|
|
|
|
|
从 package.json 中移除 `babel-plugin-import`,并从 `.babelrc` 移除该插件:
|
|
|
|
|
|
|
|
|
|
```diff
|
|
|
|
|
"plugins": [
|
|
|
|
|
- ["import", { "libraryName": "antd", "libraryDirectory": "lib"}, "antd"],
|
|
|
|
|
]
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
Umi 用户可以在配置文件中关闭:
|
|
|
|
|
|
|
|
|
|
```diff
|
|
|
|
|
// config/config.ts or .umirc
|
|
|
|
|
export default {
|
|
|
|
|
antd: {
|
|
|
|
|
- import: true,
|
2022-11-30 17:27:49 +08:00
|
|
|
|
+ import: false,
|
2022-11-21 22:33:47 +08:00
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
```
|
|
|
|
|
|
2022-11-30 17:27:49 +08:00
|
|
|
|
### 替换 Day.js 语言包
|
|
|
|
|
|
|
|
|
|
将 moment.js 的 locale 替换为 day.js 的 locale 引入:
|
|
|
|
|
|
|
|
|
|
```diff
|
|
|
|
|
- import moment from 'moment';
|
|
|
|
|
+ import dayjs from 'dayjs';
|
|
|
|
|
- import 'moment/locale/zh-cn';
|
|
|
|
|
+ import 'dayjs/locale/zh-cn';
|
|
|
|
|
|
|
|
|
|
- moment.locale('zh-cn');
|
|
|
|
|
+ dayjs.locale('zh-cn');
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
如果你暂时不想替换 day.js,也可以使用 `@ant-design/moment-webpack-plugin` 插件将 day.js 替换回 moment.js:
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
npm install --save-dev @ant-design/moment-webpack-plugin
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
// webpack-config.js
|
|
|
|
|
import AntdMomentWebpackPlugin from '@ant-design/moment-webpack-plugin';
|
|
|
|
|
|
|
|
|
|
module.exports = {
|
|
|
|
|
// ...
|
|
|
|
|
plugins: [new AntdMomentWebpackPlugin()],
|
|
|
|
|
};
|
|
|
|
|
```
|
|
|
|
|
|
2023-12-29 11:55:11 +08:00
|
|
|
|
### 使用 V4 主题包
|
2023-08-07 19:35:32 +08:00
|
|
|
|
|
|
|
|
|
如果你不希望样式在升级后发生变化,我们在兼容包中提供了完整的 V4 主题,可以还原到 V4 的样式。
|
|
|
|
|
|
|
|
|
|
```sandpack
|
|
|
|
|
const sandpackConfig = {
|
|
|
|
|
dependencies: {
|
|
|
|
|
'@ant-design/compatible': 'v5-compatible-v4',
|
|
|
|
|
},
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
import {
|
|
|
|
|
defaultTheme, // 默认主题
|
|
|
|
|
darkTheme, // 暗色主题
|
|
|
|
|
} from '@ant-design/compatible';
|
|
|
|
|
import { ConfigProvider, Button, Radio, Space } from 'antd';
|
|
|
|
|
|
|
|
|
|
export default () => (
|
|
|
|
|
<ConfigProvider theme={defaultTheme}>
|
|
|
|
|
<Space direction="vertical">
|
|
|
|
|
<Button type="primary">Button</Button>
|
|
|
|
|
<Radio.Group>
|
|
|
|
|
<Radio value={1}>A</Radio>
|
|
|
|
|
<Radio value={2}>B</Radio>
|
|
|
|
|
<Radio value={3}>C</Radio>
|
|
|
|
|
<Radio value={4}>D</Radio>
|
|
|
|
|
</Radio.Group>
|
|
|
|
|
</Space>
|
|
|
|
|
</ConfigProvider>
|
|
|
|
|
);
|
|
|
|
|
```
|
|
|
|
|
|
2022-11-30 17:27:49 +08:00
|
|
|
|
### 旧版浏览器兼容
|
|
|
|
|
|
|
|
|
|
Ant Design v5 使用 `:where` css selector 降低 CSS-in-JS hash 值优先级,如果你需要支持旧版本浏览器(如 IE 11、360 浏览器 等等)。可以通过 `@ant-design/cssinjs` 的 `StyleProvider` 去除降权操作。详情请参阅 [兼容性调整](/docs/react/customize-theme-cn#兼容性调整)。
|
|
|
|
|
|
2023-09-11 15:17:29 +08:00
|
|
|
|
## 多版本共存
|
|
|
|
|
|
|
|
|
|
一般情况下,并不推荐多版本共存,它会让应用变得复杂(例如样式覆盖、ConfigProvider 不复用等问题)。我们更推荐使用微应用如 [qiankun](https://qiankun.umijs.org/) 等框架进行分页研发。
|
|
|
|
|
|
|
|
|
|
### 通过别名安装 v5
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
$ npm install --save antd-v5@npm:antd@5
|
|
|
|
|
# or
|
|
|
|
|
$ yarn add antd-v5@npm:antd@5
|
|
|
|
|
# or
|
|
|
|
|
$ pnpm add antd-v5@npm:antd@5
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
对应的 package.json 为:
|
|
|
|
|
|
|
|
|
|
```json
|
|
|
|
|
{
|
|
|
|
|
"antd": "4.x",
|
|
|
|
|
"antd-v5": "npm:antd@5"
|
|
|
|
|
}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
现在,你项目中的 antd 还是 v4 版本,antd-v5 是 v5 版本。
|
|
|
|
|
|
|
|
|
|
```tsx
|
|
|
|
|
import React from 'react';
|
|
|
|
|
import { Button as Button4 } from 'antd'; // v4
|
|
|
|
|
import { Button as Button5 } from 'antd-v5'; // v5
|
|
|
|
|
|
|
|
|
|
export default () => (
|
|
|
|
|
<>
|
|
|
|
|
<Button4 />
|
|
|
|
|
<Button5 />
|
|
|
|
|
</>
|
|
|
|
|
);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
接着配置 ConfigProvider 将 v5 `prefixCls` 改写,防止样式冲突:
|
|
|
|
|
|
|
|
|
|
```tsx
|
|
|
|
|
import React from 'react';
|
|
|
|
|
import { ConfigProvider as ConfigProvider5 } from 'antd-v5';
|
|
|
|
|
|
|
|
|
|
export default () => (
|
|
|
|
|
<ConfigProvider5 prefixCls="ant5">
|
|
|
|
|
<MyApp />
|
|
|
|
|
</ConfigProvider5>
|
|
|
|
|
);
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
需要注意的是,npm 别名并不是所有的包管理器都有很好的支持。
|
|
|
|
|
|
2022-08-31 17:41:47 +08:00
|
|
|
|
## 遇到问题
|
|
|
|
|
|
2022-11-18 13:05:14 +08:00
|
|
|
|
如果您在升级过程中遇到了问题,请到 [GitHub issues](https://new-issue.ant.design/) 进行反馈。我们会尽快响应和相应改进这篇文档。
|