一部颠覆前端历史的框架。 React的横空出世颠覆了以往的前端发方式,本书深浅出React与Redux相关原理,重讲解前沿同构技术,揭秘SSR实战要领! 两位知名技术博主的沉淀。 本书的两位作者都是前端圈内非常活跃的技术博主,拥有丰富的实战经验,经历近十年的沉淀,将鲜活的经验通过本书分享给各位读者! 众多圈内技术大咖的力荐。 百度公司副总裁沈抖、百度公司资深前端工程师董睿、前端圈知名技术专家阮一峰、狼叔、迷渡(justjavac)、小爝、顾轶灵联合力荐!
售 价:¥
纸质售价:¥59.20购买纸书
温馨提示:数字商品不支持退换货,不提供源文件,不支持导出打印
为你推荐
书名页
内容简介
版权页
推荐序1
推荐序2
序1
序2
前言
第1章 React与前端
1.1 前端简史
1.1.1 Web 1.0
1.1.2 Web 2.0
1.2 React是什么
1.2.1 声明式
1.2.2 基于组件
1.2.3 一次学习,多端受用
1.3 React家族
1.3.1 React Router
1.3.2 Redux
1.3.3 React Native
1.4 本章小结
第2章 深入浅出React
2.1 组件
2.1.1 createClass
2.1.2 Component
2.1.3 Functional Component
2.1.4 PureComponent
2.2 组件与系统
2.2.1 传统系统
2.2.2 React系统
2.3 神奇的JSX
2.3.1 createElement
2.3.2 JSX
2.4 组件的生命周期
2.4.1 挂载
2.4.2 更新
2.4.3 卸载
2.5 组件的属性和状态
2.5.1 属性
2.5.2 状态
2.6 组件和事件
2.7 组件通信
2.7.1 父子组件
2.7.2 爷孙组件
2.7.3 兄弟组件
2.7.4 任意组件
2.8 组件的抽象与复用
2.8.1 组件的设计与抽象
2.8.2 继承
2.8.3 组合
2.8.4 高阶组件
2.9 命令式与DOM
2.9.1 ref
2.9.2 findDOMNode
2.9.3 dangerouslySetInnerHTML
2.10 本章小结
第3章 Redux应用架构基础
3.1 Redux究竟是什么
3.1.1 Redux是库结合模式
3.1.2 Redux和React的关系
3.2 Redux设计哲学
3.3 函数式编程和纯函数
3.3.1 了解“函数是一等公民”
3.3.2 了解纯函数和副作用
3.4 Redux基本使用和实践
3.4.1 初识store
3.4.2 构造action
3.4.3 使用action creator(构造器)
3.4.4 使用dispatch派发action
3.4.5 编写reducer函数更新数据
3.4.6 合理拆分reducer函数
3.5 Redux开发基础实例
3.6 reducer编写关键:不可变性
3.6.1 共享和不可变性
3.6.2 在Redux架构下保证不可变性
3.7 Redux中间件和异步
3.7.1 应用redux-logger中间件
3.7.2 应用redux-thunk中间件
3.7.3 组合使用中间件
3.8 Redux与React
3.8.1 Redux架构回顾
3.8.2 Redux和React衔接点
3.8.3 使用react-redux库
3.9 实现计数器的四种方式
3.9.1 纯React实现
3.9.2 纯Redux实现
3.9.3 React+Redux实现
3.9.4 React+Redux并使用react-redux库实现
3.10 完成一个工程化实例
3.10.1 项目目录
3.10.2 组件划分
3.10.3 确定应用数据状态
3.10.4 数据状态和相关组件数据分配
3.10.5 action和reducer
3.10.6 使用react-redux库进行连接
3.10.7 使用中间件和接入redux-devtools
3.11 本章小结
第4章 深入理解Redux
4.1 Redux源码探索——store的实现
4.2 Redux源码探索——combineReducers的实现
4.3 dispatch的改造——实现记录日志
4.4 dispatch的改造——识别Promise
4.5 糅合多种dispatch
4.6 Redux源码探索——中间件的秘密
4.6.1 源码剖析
4.6.2 写一个中间件的套路
4.7 再谈Redux设计思想
4.7.1 Redux的特性和限制
4.7.2 Redux生态
4.8 react-redux究竟是什么
4.8.1 Provider组件
4.8.2 connect方法
4.9 本章小结
第5章 揭秘React同构应用
5.1 前后端架构设计和服务端渲染概念
5.1.1 前后端配合技术的演进
5.1.2 技术历史总是惊人的相似
5.2 同构应用
5.2.1 什么是同构
5.2.2 同构的优势和劣势
5.3 使用React和Redux实现同构应用
5.3.1 使用renderToString和renderToStaticMarkup方法
5.3.2 使用renderToNodeStream和renderToStaticNodeStream方法
5.3.3 Redux搭配React实现服务端渲染
5.4 React 16在服务端渲染上的惊喜
5.5 同构项目实战:基于Node.js的“渐进式”流渲染
5.5.1 项目背景和技术栈介绍
5.5.2 项目目录
5.5.3 代码实现
5.5.4 同构应用与浏览器端渲染优势对比
5.6 使用Next.js实现同构应用
5.6.1 Next.js的极简理念
5.6.2 Next.js设计思想
5.7 使用Next.js实现同构应用
5.8 本章小结
第6章 深入理解React技术内幕与生态社区
6.1 React组件的组合和复用——高阶组件
6.1.1 高阶组件注意事项和编写原则
6.1.2 高阶组件从场景到应用
6.2 高阶组件和render prop
6.2.1 Mixins的问题
6.2.2 高阶组件和Mixins
6.2.3 render prop是什么
6.3 React组件的组合和复用——Function as Child Component
6.4 React组件的组合和复用——Children API
6.5 React“轮子”是怎样设计的
6.6 setState异步带来的讨论和思考
6.6.1 setState的同步和异步之争
6.6.2 让setState连续更新的方法
6.6.3 setState Promise化的讨论和尝试
6.7 React组件和React element到底是什么
6.8 实现一个简易的React库
6.8.1 准备工作
6.8.2 初见雏形
6.8.3 持续迭代
6.8.4 总结与思考
6.9 引入Redux的必要性及利弊
6.10 如何设计并应用Redux connect
6.11 使用selector实现最佳实践
6.11.1 selector使用实例
6.11.2 使用神奇的reselect类库
6.12 Redux store数据结构扁平化及在Twitter中的实践
6.12.1 数据结构扁平化的优化方向和手段
6.12.2 Twitter在基于Redux架构下的数据实践
6.13 React state和Redux state的选取原则
6.14 本章小结
第7章 单页面应用代码分割
7.1 React和代码分割
7.1.1 代码分割的意义和普遍做法
7.1.2 基于业务的代码分割
7.1.3 合理选择分割维度
7.1.4 合理选择加载时机
7.1.5 按需加载实现原理
7.2 Redux reducer层面代码分割
7.3 代码分割工程实例
7.3.1 依赖和业务分离
7.3.2 按需加载组件
7.3.3 收益与总结
7.4 本章小结
第8章 React应用性能优化
8.1 React应用性能的秘密
8.1.1 性能到底指什么
8.1.2 正确理解React虚拟的DOM带来的优化
8.1.3 使用React.addons.Perf进行性能调试
8.2 提升React应用性能的建议
8.2.1 最大限度地减少重新渲染
8.2.2 Redux connect方法隐藏的性能优化思想
8.2.3 inline function的反模式
8.3 使用PureComponent保证开发性能
8.4 Redux中间件和Web Worker
8.5 本章小结
买过这本书的人还买过
读了这本书的人还在读
同类图书排行榜