资源名称:同构Jav aSc ript应用开发

作者简介:

作者:[美]杰森·史特林贝尔(Jason Strimpel)、马克西姆·纳吉姆(Maxime Najim) 译者:张俊达

Jason Strimpel,软件工程师,拥有十余年Web开发经验。目前任职于沃尔玛实验室,负责支持UI应用的软件开发。

Maxime Najim,沃尔玛实验室软件架构师,全栈Web开发者。曾任职于Netflix、苹果和Yahoo!等公司,在创建大型、伸缩性强、可靠的Web应用方面具有丰富经验。

资源目录:

前言 ix

第一部分 简介与关键概念

第1章 为什么需要同构Javascript 2

1.1 定义同构Javascript 3

1.2 评价其他的Web应用架构方案 3

1.2.1 状况的改变 3

1.2.2 工程上的关注点 4

1.2.3 可选架构 4

1.3 附加说明:何时不使用同构 10

1.4 小结 11

第2章 同构Javascript图谱 12

2.1 共享视图 13

2.1.1 共享模板 14

2.1.2 共享视图逻辑 14

2.2 共享路由 14

2.3 共享模型 15

2.4 小结 15

第3章 同构Javascript分类 16

3.1 与环境无关的代码 18

3.2 为每个特定环境提供shim 19

3.3 小结 20

第4章 超越服务器端的渲染 21

4.1 实时Web应用 22

4.1.1 同构API 23

4.1.2 双向数据同步 23

4.1.3 在服务器端进行客户端仿真 23

4.2 小结 24

第二部分 构建第一个应用

第5章 起步 26

5.1 Node的安装和运行 27

5.1.1 从源码安装 27

5.1.2 与Node REPL交互 28

5.1.3 使用npm 管理项目 28

5.2 建立应用项目 29

5.2.1 初始化项目 29

5.2.2 安装应用服务器 31

5.2.3 编写下一代的Javascript(ES6) 32

5.2.4 将ES6编译为ES5 34

5.2.5 建立开发流程 35

5.3 小结 39

第6 章 提供第一份HTML文档 40

6.1 提供HTML模板 40

6.2 使用路径参数与查询参数 42

6.3 小结 45

第7章 设计应用架构 46

7.1 理解问题 47

7.2 响应用户请求 47

7.2.1 创建Application类 47

7.2.2 创建控制器 49

7.2.3 构造控制器实例 50

7.2.4 拓展控制器 52

7.2.5 改进响应流 53

7.3 小结 57

第8章 将应用传输到客户端 58

8.1 打包应用的客户端版本 58

8.1.1 选择打包库 58

8.1.2 创建打包任务 59

8.1.3 添加客户端实现 61

8.2 响应用户请求 62

8.2.1 利用History API 63

8.2.2 响应并调用History API 63

8.3 客户端路由 67

8.4 组织代码 73

8.5 小结 75

第9章 创建常用的抽象 76

9.1 何时抽象,为什么需要抽象 76

9.2 获取和设置cookie 77

9.3 重定向请求 84

9.4 小结 88

第10章 序列化、反序列化和添加事件监听 89

10.1 序列化数据 90

10.2 创建控制器实例 92

10.3 反序列化数据 93

10.4 添加DOM事件处理器 94

10.5 验证rehydration过程 96

10.6 小结 98

第11章 结束感言 99

11.1 生产准备 99

11.2 衡量架构 99

11.3 小结 102

第三部分 现实世界的解决方案

第12章 沃尔玛实验室的同构React.js方案 104

12.1 物种起源 104

12.1.1 问题 105

12.1.2 解决方案 106

12.2 React模板与模式 106

12.2.1 在服务器端渲染 106

12.2.2 在客户端恢复 110

12.3 沃尔玛采用的方法 112

12.4 克服挑战 112

12.4.1 首字节时间 112

12.4.2 组件渲染优化 113

12.4.3 性能提升 117

12.5 下一步 119

12.6 感谢 120

12.7 补充说明 120

第13章 全栈Angular 121

13.1 同构Javascript:Web应用的未来 122

13.2 同构Angular 1 122

13.3 Angular 2服务器端渲染 124

13.3.1 服务器端渲染的用例 124

13.3.2 Web 应用脱节 126

13.3.3 Angular 2渲染架构 127

13.3.4 Preboot 128

13.4 Angular Universal 128

13.5 GetHuman.com 130

13.6 补充说明 131

第14章 Brisket 132

14.1 问题 132

14.2 两全其美 134

14.3 早期Brisket 135

14.4 成为现实 136

14.5 代码自由 136

14.6 跨环境一致的API 139

14.6.1 模型/ 集合 140

14.6.2 视图生命周期 140

14.6.3 子视图管理 141

14.6.4 跨环境使用的工具 141

14.7 前进之路 142

14.7.1 ClientApp与ServerApp 142

14.7.2 布局模板 142

14.7.3 其他经验教训 143

14.8 Brisket的下一步? 143

14.9 补充说明 144

第15章 Colony案例研究:脱离Node创建同构应用 145

15.1 问题 145

15.2 模板 146

15.3 数据 147

15.4 转译视图模型 148

15.5 布局 150

15.6 页面生成器 152

15.7 前端SPA 152

15.8 最终架构 153

15.9 后续计划 154

第16 章 结语 155

16.1 设计模式、Flux和同构Javascript家族 155

16.1.1 永远相信JavaScrip 156

16.1.2 命名与理解 157

关于作者 159

关于封面 159

资源截图:

1.png

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。