2016-09-18 17:39:11 +08:00
---
2018-10-28 17:35:09 +08:00
order: 2
2018-10-10 20:21:15 +08:00
title: Real project with umi and dva
2016-09-18 17:39:11 +08:00
---
2018-10-10 20:21:15 +08:00
In real project development, you might need a data flow solution like Redux or MobX. Ant Design React is a UI library that can be used with any data flow solution and application framework within the React ecosystem. We have launched dva based on Redux, as well as a pluggable enterprise application framework umi, which is recommended for use in your projects.
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
Dva is a lightweight data flow solution based on Redux. The concept comes from elm. It supports side effects, hot module replacement, dynamic loading, react-native, SSR, etc. It has been widely used in production.
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
And [umi ](http://umijs.org/ ) is a routing-based framework that supports [next.js-like conventional routing ](https://umijs.org/guide/router.html ) and various advanced routing functions, such as [routing-level on-demand loading ](https://umijs.org/en/plugin/umi-plugin-react.html#dynamicimport ). With a complete [plugin system ](https://umijs.org/plugin/ ) that covers every life cycle from source code to build product, umi is able to support various functional extensions and business needs; meanwhile [Umi UI ](https://umijs.org/guide/umi-ui.html ) is provided to enhance the development experience and development efficiency through Visual Aided Programming (VAP).
2016-09-18 17:39:11 +08:00
2019-05-07 14:57:32 +08:00
> You may also be interested in [Ant Design Pro](https://pro.ant.design/), an Out-of-box UI solution for enterprise applications based on umi, dva and ant design.
2018-10-10 20:21:15 +08:00
2019-10-23 18:00:15 +08:00
This article will guide you to create a simple application from zero using Umi UI, dva and antd.
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
## Install Umi UI
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
It is recommended to use yarn to create an application and execute the following command.
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
> If you are using npm, execute `npm install umi -g` and the effect will be the same.
2016-09-18 17:39:11 +08:00
```bash
2019-10-23 18:00:15 +08:00
$ yarn global add umi
$ umi -v
2.10.4
```
2018-10-10 20:21:15 +08:00
2019-10-23 18:00:15 +08:00
Make sure the umi version is above 2.10.0.
2018-10-10 20:21:15 +08:00
2019-10-23 18:00:15 +08:00
## Create New App
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
Start the app,
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
```bash
$ umi ui
2019-01-26 17:05:17 +08:00
2019-10-23 18:00:15 +08:00
🚀 Starting Umi UI using umi@2.10.4...
🧨 Ready on http://localhost:3000/
2019-01-26 17:05:17 +08:00
```
2019-10-23 18:00:15 +08:00
After starting, Umi UI will automatically open the browser, then click `Create Project` , select the path and enter `App name` , as shown below.
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
< img src = "https://gw.alipayobjects.com/zos/antfincdn/kQSR2zWDQ6/26543f59-07de-44b7-8b1d-b34e1266de8b.png" width = "718" / >
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
Click `Next` , select `Basic Template` , select `antd` and `dva` on the technology stack, then click `Finish` .
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
< img src = "https://gw.alipayobjects.com/zos/antfincdn/Pz9ayQpkWw/3c8a0190-ac32-444f-812e-3d1eff422507.png" width = "718" / >
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
In the project creation process, wait a few minutes.
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
< img src = "https://gw.alipayobjects.com/zos/antfincdn/UtFy3fYg9n/bb7ef7c0-2fdb-403e-9b5a-d4ba02390483.png" width = "718" / >
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
After creating, go to `Overview` and click on the shortcut entry `Run Dev` .
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
< img src = "https://gw.alipayobjects.com/zos/antfincdn/sZj2WeXiqc/44ddbc70-386c-4c8a-8deb-6a4a93a3afb2.png" width = "718" / >
2018-10-10 20:21:15 +08:00
2019-10-23 18:00:15 +08:00
In the task page, click `Start` ,
< img src = "https://gw.alipayobjects.com/zos/antfincdn/%24ot6F6Bj2L/a4c49cda-4ff8-409f-8054-9281199b6270.png" width = "718" / >
2016-09-18 17:39:11 +08:00
2019-10-23 18:00:15 +08:00
When prompted, open [http://localhost:8000 ](http://localhost:8000 ) in your browser, you will see the welcome page of umi.
2018-10-10 20:21:15 +08:00
2019-10-23 18:00:15 +08:00
< img src = "https://gw.alipayobjects.com/zos/antfincdn/2Bm%24zoeBpz/ba708131-c7ac-41f0-92a0-c86007291b6a.png" width = "718" / >
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
## Integrate antd
2019-10-23 18:00:15 +08:00
After selecting `antd` earlier, antd's dependencies are automatically handled and loaded on demand. You can check the `Configuration` to make sure antd is turned on.
2018-10-10 20:21:15 +08:00
2019-10-23 18:00:15 +08:00
< img src = "https://gw.alipayobjects.com/zos/antfincdn/0EFiWipONe/7aea9287-09ff-4396-bb20-d8da28483c2c.png" width = "718" / >
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
> And if you want to use a fixed version of antd, you can install additional antd dependency in your project, and the antd dependencies declared in package.json will be used first.
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
## Create Routes
2016-09-18 17:39:11 +08:00
We need to write an application displaying the list of products. The first step is to create a route.
2018-10-10 20:21:15 +08:00
If you don't have npx, you need to install it first to execute the commands under node_modules.
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
```bash
2018-10-16 15:32:55 +08:00
$ yarn global add npx
2016-09-18 17:39:11 +08:00
```
2018-10-10 20:21:15 +08:00
Then create a `/products` route,
```bash
$ npx umi g page products
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
create src/pages/products.js
create src/pages/products.css
✔ success
2016-09-18 17:39:11 +08:00
```
2018-10-10 20:21:15 +08:00
Then open [http://localhost:8000/products ](http://localhost:8000/products ) in your browser and you should see the corresponding page.
2016-09-18 17:39:11 +08:00
## Write UI Components
2018-10-10 20:21:15 +08:00
As your application grows and you notice you are sharing UI elements between multiple pages (or using them multiple times on the same page), in umi it's called reusable components.
2016-09-18 17:39:11 +08:00
Let's create a `ProductList` component that we can use in multiple places to show a list of products.
2019-10-23 18:00:15 +08:00
Click `Open in editor` ,
< img src = "https://gw.alipayobjects.com/zos/antfincdn/yXRYDK88RS/2252c0f6-747f-422c-aeb6-dc518d74c8ea.png" width = "718" / >
2018-10-10 20:21:15 +08:00
Create `src/components/ProductList.js` by typing:
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
```js
2016-09-18 17:39:11 +08:00
import { Table, Popconfirm, Button } from 'antd';
const ProductList = ({ onDelete, products }) => {
2019-05-07 14:57:32 +08:00
const columns = [
{
title: 'Name',
dataIndex: 'name',
2016-09-18 17:39:11 +08:00
},
2019-05-07 14:57:32 +08:00
{
title: 'Actions',
render: (text, record) => {
return (
< Popconfirm title = "Delete?" onConfirm = {() = > onDelete(record.id)}>
< Button > Delete< / Button >
< / Popconfirm >
);
},
},
];
return < Table dataSource = {products} columns = {columns} / > ;
2016-09-18 17:39:11 +08:00
};
export default ProductList;
```
2018-10-10 20:21:15 +08:00
## Define dva Model
2016-09-18 17:39:11 +08:00
2017-06-30 02:33:17 +08:00
After completing the UI, we will begin processing the data and logic.
2016-09-18 17:39:11 +08:00
2017-10-06 16:08:03 +08:00
dva manages the domain model with `model` , with reducers for synchronous state updates, effects for async logic, and subscriptions for data source subscribe.
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
Let's create a model `src/models/products.js` by typing,
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
```js
2016-09-18 17:39:11 +08:00
export default {
namespace: 'products',
state: [],
reducers: {
2019-05-07 14:57:32 +08:00
delete(state, { payload: id }) {
2016-09-18 17:39:11 +08:00
return state.filter(item => item.id !== id);
},
},
};
```
In this model:
2019-05-07 14:57:32 +08:00
- `namespace` represents the key on global state
- `state` is the initial value, here it is an empty array
- `reducers` is equivalent to a reducer in redux, accepting an action, and update state simultaneously
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
In umi, the model files under `src/models` will be automatically injected, you don't need to inject manually.
2016-09-18 17:39:11 +08:00
## Connect
2017-10-06 16:08:03 +08:00
So far, we have completed a separate model and component. How do we connect them together?
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
dva provides a `connect` method. If you are familiar with redux, this connect is from react-redux.
2016-09-18 17:39:11 +08:00
2018-11-06 22:55:00 +08:00
Edit `src/pages/products.js` and replace it with the following,
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
```js
2016-09-18 17:39:11 +08:00
import { connect } from 'dva';
import ProductList from '../components/ProductList';
2016-11-14 14:16:12 +08:00
const Products = ({ dispatch, products }) => {
2016-09-18 17:39:11 +08:00
function handleDelete(id) {
2016-11-14 14:16:12 +08:00
dispatch({
2016-09-18 17:39:11 +08:00
type: 'products/delete',
payload: id,
});
}
return (
< div >
< h2 > List of Products< / h2 >
2016-11-14 14:16:12 +08:00
< ProductList onDelete = {handleDelete} products = {products} / >
2016-09-18 17:39:11 +08:00
< / div >
);
};
export default connect(({ products }) => ({
2016-11-14 14:16:12 +08:00
products,
2016-09-18 17:39:11 +08:00
}))(Products);
```
2018-10-10 20:21:15 +08:00
Finally, we need some initial data to make the application run together. Edit `src/app.js` ,
```js
export const dva = {
config: {
onError(err) {
err.preventDefault();
console.error(err.message);
},
initialState: {
2019-05-07 14:57:32 +08:00
products: [{ name: 'dva', id: 1 }, { name: 'antd', id: 2 }],
2018-10-10 20:21:15 +08:00
},
},
};
2016-09-18 17:39:11 +08:00
```
Refresh your browser, you should see the following result:
2018-10-10 20:21:15 +08:00
< img src = "https://zos.alipayobjects.com/rmsportal/GQJeDDeUCSTRMMg.gif" / >
2016-09-18 17:39:11 +08:00
## Build
2019-10-23 18:00:15 +08:00
Now that we've written our application and verified that it works in development, it's time to get it ready for deployment to our users. To do so, click `build` in Task page.
2018-10-10 20:21:15 +08:00
2019-10-23 18:00:15 +08:00
< img src = "https://gw.alipayobjects.com/zos/antfincdn/P31ZGMwzGe/d5365860-f7c6-4abe-98c0-36d6b1b3a65a.png" width = "718" / >
2016-09-18 17:39:11 +08:00
2018-10-10 20:21:15 +08:00
The `build` command packages up all of the assets that make up your application —— JavaScript, templates, CSS, web fonts, images, and more. Then you can find these files in the `dist/` directory.
2016-09-18 17:39:11 +08:00
## What's Next
We have completed a simple application, but you may still have lots of questions, such as:
2019-05-07 14:57:32 +08:00
- How to handle onError globally and locally?
- How to handle routes?
- How to mock data?
- How to deploy?
- ant so on...
2016-09-18 17:39:11 +08:00
You can:
2019-05-07 14:57:32 +08:00
- Visit [umi official website ](https://umijs.org/ ) and [dva official website ](https://dvajs.com/ )
- Know [the umi routes ](https://umijs.org/zh/guide/router.html )
- Know [how to deploy umi application ](https://umijs.org/zh/guide/deploy.html )
- Checkout [dva knowledge ](https://dvajs.com/knowledgemap/ ), including all the basic knowledge with ES6, React, dva
- Be familiar with the [8 Concepts of dva ](https://dvajs.com/guide/concepts.html ), and understand how they are connected together