注册 登录 进入教材巡展
#
  • #

出版时间:2018-07

出版社:电子工业出版社

以下为《揭秘Angular(第2版)》的配套数字资源,这些资源在您购买图书后将免费附送给您:
  • 电子工业出版社
  • 9787121342721
  • 2版
  • 301497
  • 2018-07
作者简介
广发证券互联网金融技术团队,是早期拥抱 Angular 的坚定践行者。作为全新一代的证券业 IT 研发组织,团队致力于用*新*好的技术打造行业方案、支持业务创新。我们热爱开源技术、信奉敏捷方法、编写优雅代码、关注用户体验,我们喜欢互联网工程师文化,我们在技术创新中寻找到乐趣。
查看全部
内容简介
本书作为前版《揭秘Angular 2》的重大升级,是紧跟新版本的实战quan威指南。Angular诞生于Google,已用于多款Google及全球商业产品。它是一套JavaScript前端框架,旨在开发当下流行的数据驱动的单页面Web应用,其核心特性是:MVC、模块化、自动双向数据绑定、语义化标签、依赖注入等。作为一部系统讲解流行前端框架 Angular 新版的权wei著作,本书覆盖入门、进阶和实战三大主题。部分从前端的故事起点说起,然后对Angular以及TypeScript进行了简单的介绍,接着通过一个通讯录例子让读者快速入门 Angular 的开发;第二部分则深入讲解了 Angular 架构以及 Angular 核心内容,包括组件、模板、指令、服务、依赖注入、路由以及测试,此外,在相应的章节里还补充说明了譬如变化监测的核心 Zones(第6章)、双向绑定的原理(第7章)、RxJS(第9章)等关键内容;第三部分则通过问卷调查系统来指引读者进行 Angular 项目的实战;第四部分主要是 Angular 延伸知识的讲解,介绍了 ionic 框架(第 19 章)以及 Angular 的服务端渲染(第 20 章)相关技术。
目录

目录

第一部分入门篇
1 前端风云 2
1.1 故事的起点 2
1.2 AJAX 王者归来 3
1.3 工具库的流行 3
1.4 百家争鸣 3
1.5 走进前端新时代 4
1.6 小结 6

2 Angular 简介 7
2.1 历史回顾 7
2.1.1 AngularJS 1.x 起源 7
2.1.2 AngularJS 1.x 迭代之路 8
2.1.3 初生的Angular 9
2.1.4 快速发展的Angular 10
2.1.5 Angular 4 和后续语义版本 11
2.1.6 开发语言之选 13
2.2 Angular 简述 14
2.2.1 核心概念 14
2.2.2 平台简介 16
2.2.3 平台亮点 18
2.3 小结 19

3 TypeScript 入门 20
3.1 TypeScript 概述 20
3.1.1 概述 20
3.1.2 安装 21
3.2 基本类型 22
3.2.1 布尔类型 22
3.2.2 数字类型 22
3.2.3 字符串类型 23
3.2.4 数组类型 23
3.2.5 元组类型 23
3.2.6 枚举类型 23
3.2.7 任意值类型 24
3.2.8 null 和undefined 24
3.2.9 void 类型 25
3.2.10 never 类型 26
3.3 声明和解构 26
3.3.1 let 声明 27
3.3.2 const 声明 28
3.3.3 解构 28
3.4 函数 30
3.4.1 函数定义 30
3.4.2 可选参数 30
3.4.3 默认参数 31
3.4.4 剩余参数 32
3.4.5 函数重载 32
3.4.6 箭头函数 33
3.5 类 34
3.5.1 类的例子 34
3.5.2 继承与多态 34
3.5.3 修饰符 35
3.5.4 参数属性 37
3.5.5 静态属性 37
3.5.6 抽象类 38
3.6 模块 39
3.6.1 概述 39
3.6.2 模块导出方式 39
3.6.3 模块导入方式 40
3.6.4 模块的默认导出 41
3.6.5 模块设计原则 42
3.7 接口 44
3.7.1 概述 44
3.7.2 属性类型接口 44
3.7.3 函数类型接口 45
3.7.4 可索引类型接口 46
3.7.5 类类型接口 46
3.7.6 接口扩展 47
3.8 装饰器 48
3.8.1 概述 48
3.8.2 方法装饰器 49
3.8.3 类装饰器 50
3.8.4 参数装饰器 52
3.8.5 属性装饰器 53
3.8.6 装饰器组合 53
3.9 泛型 55
3.10 TypeScript 周边 56
3.10.1 编译配置文件 56
3.10.2 声明文件 57
3.10.3 编码工具 58
3.10.4 展望未来 59
3.11 小结 59

4 快速入门 60
4.1 Hello World 例子 60
4.1.1 准备工作 60
4.1.2 构建项目 61
4.2 通讯录例子 66
4.2.1 背景介绍 66
4.2.2 架构设计 68
4.3 小结 74

第二部分深入篇
5 Angular 架构总览 76
5.1 核心模块介绍 76
5.1.1 组件 77
5.1.2 模板 81
5.1.3 指令 83
5.1.4 服务 84
5.1.5 依赖注入 84
5.1.6 路由 86
5.2 应用模块 89
5.3 源码结构介绍 92
5.4 小结 93

6 组件 94
6.1 概述 94
6.1.1 模块化介绍 94
6.1.2 组件化标准 96
6.1.3 Angular 的组件 99
6.2 组件基础 100
6.2.1 创建组件的步骤 100
6.2.2 组件的基础构成 101
6.2.3 组件与模块 108
6.3 组件交互 113
6.3.1 组件的输入、输出属性 113
6.3.2 父组件向子组件传递数据 114
6.3.3 子组件向父组件传递数据 120
6.3.4 其他组件交互方式 121
6.4 组件内容嵌入 124
6.5 组件生命周期 128
6.5.1 概述 128
6.5.2 生命周期钩子 128
6.6 变化监测 130
6.6.1 数据变化的源头 131
6.6.2 变动通知机制 132
6.6.3 变化监测的响应处理 134
6.7 扩展阅读 140
6.7.1 元数据一览表 140
6.7.2 元数据说明 141
6.7.3 深入理解Zone.js 150
6.7.4 不依赖Zone.js 的Angular 154
6.8 小结 155

7 模板 156
7.1 模板语法概览 156
7.2 数据绑定 158
7.2.1 概述 158
7.2.2 插值 160
7.2.3 模板表达式 160
7.2.4 属性绑定 162
7.2.5 事件绑定 165
7.2.6 双向数据绑定 168
7.2.7 输入和输出属性 169
7.3 内置指令 170
7.3.1 NgClass 170
7.3.2 NgStyle 170
7.3.3 NgIf 171
7.3.4 NgSwitch 172
7.3.5 NgFor 172
7.4 表单 173
7.4.1 模板表单例子 174
7.4.2 表单指令 175
7.4.3 自定义表单样式 184
7.4.4 表单校验 186
7.5 管道 189
7.5.1 管道介绍 189
7.5.2 内置管道 190
7.5.3 自定义管道 196
7.5.4 管道的变化监测 198
7.6 扩展阅读 202
7.6.1 安全导航操作符 202
7.6.2 双向绑定的原理 202
7.7 小结 204

8 指令 206
8.1 概述 206
8.1.1 指令分类 208
8.1.2 内置指令 210
8.2 自定义属性指令 219
8.2.1 实现属性指令 219
8.2.2 为指令绑定输入 221
8.2.3 响应用户操作 223
8.3 自定义结构指令 224
8.3.1 实现结构指令 225
8.3.2 模板标签与星号前缀 227
8.3.3 NgIf 指令原理 229
8.4 扩展阅读 231
8.5 小结 235

9 服务与RxJS 237
9.1 Angular 服务 237
9.1.1 概述 237
9.1.2 使用场景 238
9.2 HTTP 服务 242
9.2.1 HttpModule 242
9.2.2 HttpClientModule 254
9.3 响应式编程 262
9.3.1 概述 262
9.3.2 ReactiveX 264
9.4 RxJS 266
9.4.1 创建Observable 对象 266
9.4.2 使用RxJS 处理复杂场景 266
9.4.3 RxJS 和Promise 的对比 267
9.4.4 “冷”模式下的Observable 268
9.4.5 RxJS 中的Operator 269
9.4.6 Angular 中的RxJS 273
9.5 小结 277

10 依赖注入 278
10.1 依赖注入介绍 279
10.2 Angular 依赖注入 282
10.2.1 概述 282
10.2.2 在组件中注入服务 285
10.2.3 在服务中注入服务 287
10.2.4 在模块中注入服务 288
10.2.5 层级注入 290
10.2.6 注入到派生组件 295
10.2.7 限定方式的依赖注入 297
10.3 Provider 300
10.3.1 概述 300
10.3.2 Provider 注册方式 302
10.4 扩展阅读 305
10.5 小结 308

11 路由 309
11.1 概述 309
11.2 基本用法 311
11.2.1 路由配置 311
11.2.2 创建根路由模块 312
11.2.3 添加RouterOutlet 指令 312
11.3 路由策略 313
11.3.1 HashLocationStrategy 介绍 314
11.3.2 PathLocationStrategy 介绍 315
11.4 路由跳转 316
11.4.1 使用指令跳转 317
11.4.2 使用代码跳转 319
11.5 路由参数 321
11.5.1 Path 参数 321
11.5.2 Query 参数 324
11.5.3 Matrix 参数 326
11.6 子路由和附属Outlet 326
11.6.1 子路由 326
11.6.2 附属Outlet 328
11.7 路由拦截 330
11.7.1 激活拦截与反激活拦截 330
11.7.2 数据预加载拦截 334
11.8 模块的延迟加载 337
11.8.1 延迟加载实现 337
11.8.2 模块预加载 339
11.8.3 模块加载拦截 341
11.9 小结 342

12 测试 343
12.1 概述 343
12.2 单元测试 344
12.2.1 概述 344
12.2.2 常用测试框架 345
12.2.3 Jasmine 介绍 345
12.2.4 Karma 介绍 350
12.2.5 Karma 结合Jasmine 测试 350
12.3 Angular 单元测试 355
12.3.1 概述 355
12.3.2 独立单元测试 358
12.3.3 测试工具集 362
12.4 端到端测试 370
12.4.1 概述 370
12.4.2 Protractor 介绍 371
12.5 小结 374

第三部分实战篇
13 问卷调查系统简介 376
13.1 项目背景 376
13.2 主要特性 377
13.2.1 首页和帮助页 378
13.2.2 问卷编辑页 378
13.2.3 我的问卷页 378
13.2.4 用户管理页 379
13.3 产品设计 379
13.4 小结 380

14 项目起步 381
14.1 Angular CLI 381
14.1.1 简介 381
14.1.2 常用命令介绍 382
14.2 其他技术选型 391
14.2.1 UI 样式库 391
14.2.2 后端服务器 391
14.3 环境搭建 392
14.3.1 搭建前端环境 392
14.3.2 引入样式库 393
14.3.3 搭建后端环境 394
14.4 目录结构介绍 396
14.5 首页开发 397
14.6 导航栏开发 401
14.7 小结 402

15 问卷编辑模块 403
15.1 概述 403
15.1.1 特性管理模块 403
15.1.2 功能设计 406
15.1.3 数据模型 407
15.2 问卷编辑模块开发 410
15.2.1 问题选择组件 410
15.2.2 问题组件 414
15.2.3 问卷组件 425
15.2.4 问卷服务 431
15.2.5 问卷大纲组件 438
15.3 小结 441

16 我的问卷模块 442
16.1 问卷列表 443
16.1.1 问卷列表项 443
16.1.2 显示问卷列表 445
16.1.3 显示问卷详情 447
16.2 问卷操作 449
16.2.1 发布后的问卷页面 450
16.2.2 问卷操作组件 453
16.3 小结 456

17 用户管理模块 457
17.1 开发简单注册页 458
17.2 表单控件组件 460
17.2.1 定义表单控件 460
17.2.2 校验表单控件 461
17.2.3 表单安全 464
17.3 用户注册功能开发 465
17.3.1 用户注册服务 465
17.3.2 组件的逻辑 466
17.3.3 注册接口开发 469
17.4 权限管理 470
17.5 小结 473

18 项目构建和最佳实践 475
18.1 项目构建 475
18.1.1 代码质量检查 475
18.1.2 测试 476
18.1.3 打包 478
18.1.4 容器化 479
18.2 最佳实践 479
18.2.1 单一职责 480
18.2.2 命名约定 480
18.2.3 编码约定 483
18.2.4 Angular 模块约定 487
18.2.5 组件相关约定 487
18.2.6 指令相关约定 489
18.2.7 服务相关约定 490
18.2.8 其他 491
18.3 小结 492

第四部分延伸篇
19 移动开发框架:ionic 介绍与实战 494
19.1 移动开发 494
19.1.1 背景介绍 494
19.1.2 四种开发模式 495
19.1.3 技术选型 495
19.2 ionic 平台介绍 496
19.2.1 概览 496
19.2.2 Cordova 498
19.2.3 环境搭建 499
19.2.4 组件开发 501
19.2.5 路由和导航 503
19.3 ionic Native 507
19.3.1 插件介绍 507
19.3.2 插件使用 508
19.3.3 插件开发 509
19.4 样式和主题 509
19.4.1 平台样式 509
19.4.2 主题 511
19.4.3 全局变量 512
19.4.4 工具属性 513
19.4.5 Iconfont 514
19.5 ionic CLI 515
19.6 通讯录实例 518
19.6.1 项目搭建 519
19.6.2 主页面 520
19.7 小结 525

20 服务端渲染 527
20.1 概述 527
20.2 客户端渲染的局限性 528
20.3 服务端渲染的局限性 529
20.4 Angular Universal 介绍 531
20.5 将通讯录例子改造成Angular Universal 的方式 533
20.6 服务端渲染的进阶实践 540
20.6.1 服务端数据的同步 541
20.6.2 使用依赖注入解决环境差异 544
20.6.3 使用Preboot 解决事件脱节 546
20.7 小结 549

Baidu
map