前两篇写了react各种基本操作和主要概念
但其实没必要那么复杂直接用框架就好啦
这年头前端框架真是一睁眼就多出好几个
傻瓜级教程写的不合理的地方请批评指正
React官网:https://reactjs.org/
菜鸟教程:http://www.runoob.com/react/react-tutorial.html
ES6入门: http://es6.ruanyifeng.com/
Ant Design:https://ant.design/index-cn
Redux: https://www.redux.org.cn/
Dva:https://github.com/dvajs/dva
先附上上上篇的链接。React爬坑之路一:React+Antd+Axios
和上篇的链接。React爬坑之路二:Router+Redux
第一篇其实说过了,之所以在简书记录了一下React是因为工作培训时小哥给的Dva工程ST发现一行都看不懂 = =
原本想在研究Dva之前先简写下React的基本概念,没想到写太多直接更新了两篇博客。
那么现在终于可以来研究Dva啦。
Dva是守望先锋中一个热门英雄,拥有一部强大的机甲,同时具有两台全自动的近距离聚变机炮……
诶,不是这个Dva吗Σ(⊙▽⊙")
七. 创建Dva工程
我们前两篇都是用create-react-app创建工程的,但是它只能创建一个最基本的空程序。在前两篇中,我们自己用npm装上了router,redux等依赖包,并自己手动写了很多操作。
Dva将上述一切进行了简化,它是一个封装好很多模块的框架,并且拥有自己的脚手架。用Dva创建的工程,从目录结构起就非常清晰。(虽然框架这种东西可以简化很多操作,但在使用框架前还是不能忘记本源,所以建议前两篇也粗略的看一看。)
npm install dva-cli -g
用dva -v可以查看版本号。
dva版本.png
跟create-react-app一样,用dva在命令行创建app。
dva new dva-app
其后进入工程文件并启动工程。
cd dva-app
npm start
Dva工程.png
(Yay!…为什么是一个小丑啊눈_눈,这让有恐怖片小丑恐惧症的人情何以堪)
Dva工程的目录结构如下:
Dva目录结构.png
可以看出,比create-react是多了很多东西的。
除了index.js的入口文件,和router.js的初始路由,上面那些文件夹里大致意义如下:
asserts 用于存放静态资源,跟以往正常的java工程一样,里面扔图片视频之类的。
components 用于存放公共组件,比如页面头尾导航条。
routes 用于存放路由组件,可以通俗的理解成页面。与component的区别在于一般是非公共的并且会跟model里的数据模型联系起来。
models 用于存放模型文件,(个人认为model才是react-redux体系里最重要的部分),我们之前说的state以及reducer都会写在里面,同时,通过connect跟routes里面的组件进行绑定。routes中的组件通过connect拿到model中的数据,model也能通过connect接收到组件中dispatch的action。
services 用于存放跟后台交互的服务文件,一般都需要调用后台的接口。
utils 用于存放工具类库。
其他的配置文件暂时不管啦。
整体的流程大致(数据流向)是:
从index入口进入 => 通过url匹配routes里的组件(顺便看看components里有没有啥公共组件要加载过来) => routes里的组件dispatch action => model通过action改变state(中途可能会通过services跟后台交互) => 通过connect重新渲染routes中的组件
画的不对不要怪我.png
八. 实践出真知
理论不如实践,那么,我们用Dva搞一个前两篇中的例子试一试,路由切换并且做个表格。(其实具体各个函数的写法跟前两篇中基本一样,只是写的位置不一样。下面详解。)
路由aaa.png
路由bbb.png
首页.png
入口文件:
首先,在入口文件index.js中,能看到已经给我们留了model模型和router路由的位置。在开发中,所有的model模型文件都需要在这里注册,这样才能用connect跟组件联系起来。
// 1. Initialize
const app = dva();
// 2. Plugins
// app.use({});
// 3. Model
// app.model(require(’./models/example’).default);
// 4. Router
app.router(require(’./router’).default);
// 5. Start
app.start(’#root’);
先不管Model,Router告诉我们引用了router.js,打开看一眼。
import IndexPage from ‘./routes/IndexPage’;
……
只有一个,通俗易懂,在路径为/的时候匹配到IndexPage。(不用我们自己装Router自己建立router.js自己配置了是不是很方便~)注意这里加了exact,表示精确匹配,如果不加则/aaa, /bbb, /whatever都会匹配到IndexPage,精确匹配的话只有输入/的时候才会匹配。
IndexPage里能看到欢迎信息,那个小丑图片和提示文字,这里就不贴过来了。
路由切换:
下面我们自己做个路由切换的效果。
Step1: 装Antd!虽然Dva很贴心的封装了很多工具包但是并没有封装样式库,所以Antd还是需要自己装的。
npm install antd
npm install babel-plugin-import
并编辑.webpackrc文件。
{
“extraBabelPlugins”: [
[“import”, {
“libraryName”: “antd”,
“libraryDirectory”: “es”,
“style”: true
}]
]
}
这样就可以使用Antd了。
Step2: 新增组件
下一步我们需要新建一些组件:
新建一些组件.png
我们在routes里面新建aaa.js和bbb.js两个组件。内容随便写点啥,反正只是为了切换用。
// aaa.js
import React, { Component } from ‘react’
import { connect } from ‘dva’
class AAA extends Component { //BBB同理
render() {
return (
AAA
)
}
}
AAA.propsTypes = {}
export default connect()(AAA)
Step3: 定义导航栏
然后,在components里建立两个公共组件header.js和layout.js。
header.js用作页面上方的导航栏,理想效果如下,通过点击不同导航切换地址栏url。
header.png
header.js需要引入antd的Menu模块,以及dva封装好的Link。Link的作用即匹配相应的路径,在爬坑之路二里我们也用到过。
// header.js
……
import { Menu } from ‘antd’;
import { Link } from ‘dva/router’
class Header extends Component {
render() {
return (