react初次实践总结

前言

上周用了一个礼拜,了解了react的理论知识,依然一头雾水;
本周直接参照项目代码,真正着手去写项目模块,终于能正式把react中的数据串通;

目录

  1. 工具 & 准备
  2. dva项目框架结构
  3. dva框架下的react项目的数据流通
  4. 学习资料推荐
  5. 总结

1. 工具 & 准备

dva-cli框架

dva结构介绍
dva 官方中文文档
使用 dva 所需的所有知识点

在react的发展过程中,比较主流的几个框架从flux,发展到redux,在这些的基础上,dva-cli这一个脚手架工具,帮助我们更加轻松地完成react开发,而其完成的部分,就是为一个项目的逻辑、数据、页面,提供了一个很好的划分、管理、组织、通信的系统。

点击此处查看更详细的介绍:《dva搭建简易react项目实践总结》

2. dva项目框架结构

react项目的推荐目录结构(如果使用dva脚手架创建,则自动生成如下)

|── /mock/             # 数据mock的接口文件  
|── /src/              # 项目源码目录(我们开发的主要工作区域)   
|   |── /components/   # 项目组件(用于路由组件内引用的可复用组件)   
|   |── /routes/       # 路由组件(页面维度) 
|   |  |── route1.js  
|   |  |── route2.js   # 根据router.js中的映射,在不同的url下,挂载不同的路由组件
|   |  └── route3.js    
|   |── /models/       # 数据模型(可以理解为store,用于存储数据与方法)  
|   |  |── model1.js  
|   |  |── model2.js   # 选择分离为多个model模型,是根据业务实体进行划分
|   |  └── model3.js  
|   |── /services/     # 数据接口(处理前台页面的ajax请求,转发到后台)   
|   |── /utils/        # 工具函数(工具库,存储通用函数与配置参数)     
|   |── router.js       # 路由配置(定义路由与对应的路由组件)  
|   |── index.js       # 入口文件  
|   |── index.less      
|   └── index.html     
|── package.json       # 项目信息  
└── proxy.config.js    # 数据mock配置  
index.js文件介绍
// 引入dva库
import dva from 'dva';
// 引入dva的路由库
import { useRouterHistory, browserHistory, hashHistory } from 'dva/router';

// 初始化,创建dva实例
const app = dva({history: browserHistory});

// 使用插件
app.use(Hooks)

// 在index.js中注册models文件夹下的所有用到的model
// 之前提到过,redux的一大原则就是唯一数据源,即单个应用内只有一个store,状态是一个树形对象
// 功能不同的业务实体分别挂在到这一唯一store下,是二级元素
// 注册后才能将model1、model2、model3中的state与函数等属性,挂载到全局唯一的store中去
app.model(require('./models/model1'));
app.model(require('./models/model2'));
app.model(require('./models/model3'));

// 注册路由文件
app.router(require('./router'));

// 将dva实例绑定到DOM树中的#root元素,意为所有的react-Dom都加载于root节点下
app.start('#root');
router.js文件介绍

包含应用中的路由映射,url ==> 路由组件route

import React, { PropTypes } from 'react';
import { Router, Route, IndexRoute, IndexRedirect } from 'dva/router';


import App from './routes/App';
import Login from './routes/Login';

export default function({ history }) {
  return (
    <Router history={history}>
      <Route path={`/`} component={App}>
        // 添加一级子路由
        <IndexRoute component={Login} />   // 指定默认首页页面
        <Route path={`login`} component={Login} />   
        <Route path={`route1`} component={route1} />
        // 添加二级子路由 
        <Route path={`route1/subroute`} component={route1} />          
        <Route path={`route2`} component={route2} >
        <Route path={`route3`} component={route3} />
        </Route>
      </Route>
    </Router>
  );
};

3. dva框架下的react项目的数据流通

dva_concepts(来源于网络的dva项目通路)
我的个人理解与总结

步骤注解:

1.项目入口文件:index.js
2.根据浏览器中访问的url到router.js中查找对应的Route组件,完成初始的页面渲染
3.在组件被初始渲染时,依次调用以下方法:

当组件在客户端被实例化,第一次被创建时,以下方法依次被调用:  
1、getDefaultProps       // 获取默认props值,对于每个组件实例来讲,这个方法只会调用一次
2、getInitialState       // 获取初始私有state
3、componentWillMount    // 在组件生成前执行其中的方法
4、render                // 组件渲染
5、componentDidMount     // 组件生成后调用其中的方法

//在componentDidMount函数执行时,已经渲染出真实的DOM,可以通过this.refs.[refName]获取真实DOM

在选择性完成以上几个生命钩子后,组件已经正式渲染完成,可以与用户完成交互
4.可以为渲染出的React-DOM元素绑定交互事件,将用户的请求转为dispatch,通过dispatch对象到对应的model中寻找effects方法;

// 以点击事件为例
// 点击后,通过全局唯一的dispatch对象,向model层派发一个action
onclick = () => {
  const dispatch = this.props.dispatch;    // 获取全局的派发对象 dispatch
  dispatch({
    type: 'model1/effect1',   // type: 在名为'model1'的数据模型中查找effects属性中的'effect1'函数
    payload:  { key: value }  // payload:传入当前type的参数对象
  })
}

5.组件完成渲染后,组件处于存在期,当因为用户的操作或其他,导致与当前组件绑定的model.state或组件内的state发生改动时,会依次调用以下方法,对组件进行重新渲染(此轮步骤可多次循环):

1、componentWillReceiveProps    // 当前组件绑定的model.state或组件内的state发生改动时,调用其中方法
2、shouldComponentUpdate     // 判断是否进行重新渲染
3、componentWillUpdate       // 在组件接收到了新的 props 或者 state 即将进行重新渲染前,执行
4、render                    // 重新渲染
5、componentDidUpdate        // 组件重新渲染之后调用

6.切换url时,对应的路由组件随之更换,组件被销毁,在组件销毁前执行以下操作:

componentWillUnmount   // 在组件销毁之前执行,比如用于解绑事件监听、计时器等

4. 学习资料:

以下介绍的教程,我个人觉得知识点有些细,比较适合用于后期巩固查露的,前期可以跟着网上的项目着手去实践,后期再来了解具体原理
阮一峰React教程
使用 dva 所需的所有知识点

总结

对于react的学习最大的感悟就是要在实践中,梳理数据流通的路径,当熟练了这一个流通路径之后,剩余的就是一个数据读取与写入的劳动。

也是通过这一次操作,体会到了传说中的React的数据流通的“复杂性”,确实相对于Vuex来说,缺少了双向绑定,但是React的优势就是在于数据的高效单向传输,以及DOM的高效渲染。

每一个工具都有它的独特性,多练就能体会到它的好用。

在写这篇笔记时,距离笔记中所记录的初次实践已经过去了两个礼拜,在期间也遇到了无数的技术问题,努力踩坑中......

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,014评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,796评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,484评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,830评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,946评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,114评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,182评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,927评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,369评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,678评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,832评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,533评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,166评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,885评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,128评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,659评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,738评论 2 351

推荐阅读更多精彩内容