--- order: 3 title: Real project with dva --- [dva](https://github.com/dvajs/dva) is a React and redux based, lightweight and elm-style framework, which supports side effects, hot module replacement, dynamic on demand, react-native, SSR. And it has been widely used in production environment. This article will guide you to create a simple application from zero using dva and antd. Include the following: --- ## Install dva-cli Install dva-cli with npm, and make sure the version is larger then `0.7.0`. ```bash $ npm install dva-cli -g $ dva -v 0.7.0 ``` ## Create New App After installed dva-cli, you can have access to the `dva` command in terminal. Now, create a new application with `dva new`. ```bash $ dva new dva-quickstart ``` This creates `dva-quickstart` directory, that contains the project directories and files, and provides development server, build script, mock service, proxy server and so on. Then `cd` the `dva-quickstart` directory, and start the development server. ```bash $ cd dva-quickstart $ npm start ``` After a few seconds, you will see the following output: ```bash Compiled successfully! The app is running at: http://localhost:8000/ Note that the development build is not optimized. To create a production build, use npm run build. ``` Open http://localhost:8989 in your browser, you will see dva welcome page. ## Integrate antd Install `antd` and `babel-plugin-import` with npm. `babel-plugin-import` is used to automatically import scripts and stylesheets from antd in demand. See [repo](https://github.com/ant-design/babel-plugin-import) 。 ```bash $ npm install antd babel-plugin-import --save ``` Edit `.roadhogrc` to integrate `babel-plugin-import`. ```diff "extraBabelPlugins": [ - "transform-runtime" + "transform-runtime", + ["import", { "libraryName": "antd", "style": "css" }] ], ``` > Notice: dva-cli's build and server is bases on roadhog, view [roadhog#Configuration](https://github.com/sorrycc/roadhog/blob/master/README_en-us.md#configuration) for more `.roadhogrc` Configuration. ## Define Router We need to write an application displaying the list of products. The first step is to create a route. Create a route component `routes/Products.js`: ```javascript import React from 'react'; const Products = (props) => (
## Build Now that we've written our application and verified that it works in development, it's time to get it ready to deploy to our users. To do so, run the following command: ```bash $ npm run build ``` After a few seconds, the output should be as follows: ```bash > @ build /private/tmp/myapp > roadhog build Creating an optimized production build... Compiled successfully. File sizes after gzip: 82.98 KB dist/index.js 270 B dist/index.css ``` 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. ## What's Next We have completed a simple application, but you may still have lots of questions, such as: - How to dealing with async logic - How to load initial data elegantly - How to handle onError globally and locally - How to load Routes and Models on demand - How to implement HMR - How to mock data - and so on... You can: - Visit [dva official website](https://github.com/dvajs/dva). - View all the [API](https://github.com/dvajs/dva#api). - View [tutorial](https://github.com/dvajs/dva-docs/blob/master/v1/zh-cn/tutorial/01-%E6%A6%82%E8%A6%81.md), complete a medium application step by step. - View examples, such as [dva version of hackernews](https://github.com/dvajs/dva-hackernews).