Ant Design of React 提供开箱即用的高质量 React 组件,具体的UI组件参见Ant Design 文档。
Ant Design简介
Ant Design of React 是 Ant Design 的 React 实现。
npm安装:npm install antd --save
按需加载: 使用 babel-plugin-import,babel-plugin-import 会帮助你加载 JS 和 CSS,只需从 antd 引入模块即可,无需单独引入样式。
使用示例:
快速上手:
利用antd-init脚手架生成应用实例。(注意: antd-init只用于学习和体验antd如何使用,实际业务项目建议使用 dva-cli 和 create-react-app 进行搭建)$ npm install antd-init -g -> $ mkdir antd-demo && cd antd-demo -> $ antd-init
index.js
$ npm start, 访问http://127.0.0.1:8000UI样式如下:


$ npm run build,入口文件会构建到 dist 目录中,可以自由部署到不同环境中进行引用。
项目实战 dva
dva 是一个基于 React 和 Redux (Redux 或者 MobX 为数据应用框架) 的轻量应用框架,概念来自 elm,支持 side effects、热替换、动态加载、react-native、SSR 等,已在生产环境广泛应用。
Ant Design React 作为一个 UI 库,搭配 React 生态圈内的Redux,构建了轻量应用框架dva。
(1)安装dva-cli
(2)创建新应用
以上命令用于创建 dva-quickstart 目录,包含项目初始化目录和文件,并提供开发服务器、构建脚本、数据 mock 服务、代理服务器等功能。
接下来启动开发服务器:
在浏览器访问http://localhost:8000 ,会看到 dva 的欢迎界面。
(3)使用antd
通过 npm 安装 antd 和 babel-plugin-import(用来按需加载 antd 的脚本和样式,而不是把整个库都引入,从而提高性能) 。
注意: 一定要用cnpm,npm真的慢出天际。。。。
接下来编辑 .webpackrc,使 babel-plugin-import 插件生效:
(4)定义路由
写个应用来显示产品列表。首先第一步是创建路由,路由可以想象成是组成应用的不同页面,src/routes下是存放页面的。
新建 route component src/routes/Products.js,内容如下:
添加路由信息到路由表,编辑 router.js(处理页面路由):
在浏览器里打开 http://localhost:8000/#/products ,能看到前面定义的 <h2> 标签。
(5)编写 UI Component
编写一个 ProductList component。新建 components/ProductList.js 文件:
其中<Table />的columns用于表格列的配置描述,类型ColumnProps[]。见文档
(6)定义 Model
完成 UI 后,现在开始处理数据和逻辑。
dva 通过 model 的概念把一个领域的模型管理起来,包含同步更新 state 的 reducers,处理异步逻辑的 effects,订阅数据源的 subscriptions 。
新建 model models/products.js:
上述 model 里:
namespace表示在全局 state 上的 keystate是初始值,在这里是空数组reducers等同于 redux 里的 reducer,接收 action,同步更新 state
然后在index.js中载入:
(7)connect 起来
将 model 和 component 串联起来。dva 提供了 connect 方法,类似于 react-redux 的 connect,用于将 model 和 component 串联起来。
编辑 src/routes/Products.js(页面展示组件),替换为以下内容:
最后mock一些初始数据让此应用运行起来,编辑index.js:
(8)构建应用
完成开发并且在开发环境验证之后,接下来部署到生产环境:
几秒后控制台输出如下:
build 命令会打包所有的资源,包含 JavaScript, CSS, web fonts, images, html 等,可以在 dist/ 目录下找到这些文件。
在 create-react-app 中使用 antd
(1)安装和初始化
在命令行中安装 create-react-app 工具:
新建一个项目:
工具会自动初始化一个脚手架并安装 React 项目的各种必要依赖。接下来进入项目并启动,浏览器会访问 http://localhost:3000/:
(2)引入 antd
npm 安装并引入 antd:
修改 src/App.js,引入 antd 的按钮组件:
修改 src/App.css,在文件顶部引入 antd/dist/antd.css:
现在可以看到页面上已经有了 antd 的蓝色按钮组件。
(3)高级配置
步骤(2)已经把组件成功运行起来了,但是在实际开发过程中还有很多问题,例如上面的例子实际上加载了全部的 antd 组件的样式(对前端性能是个隐患)。
需要对 create-react-app 的默认配置进行自定义,这里使用 react-app-rewired (一个对 create-react-app 进行自定义配置的社区解决方案)。
引入 react-app-rewired 并修改 package.json 里的启动配置:
|
|
然后在项目根目录创建一个 config-overrides.js 用于修改默认配置:
使用 babel-plugin-import(用于 按需加载 组件代码和样式的 babel 插件),安装它并修改 config-overrides.js 文件:
|
|
然后移除前面在 src/App.css 里全量添加的 @import '~antd/dist/antd.css'; 样式代码,并且按下面的格式引入模块:
需要重启npm start访问页面,否则看不到效果。antd 组件的 js 和 css 代码都会按需加载。
自定义主题:自定义主题需要用到 less 变量覆盖功能,可以引入 react-app-rewire 的 less 插件 react-app-rewire-less 来帮助加载 less 样式,同时修改 config-overrides.js 文件:
|
|
这里利用了 less-loader 的 modifyVars 来进行主题配置,修改配置后需要重启 npm start才能看到效果。
