您好,欢迎来到聚文网。
登录
免费注册
网站首页
|
搜索
热搜:
磁力片
|
漫画
|
购物车
0
我的订单
商品分类
首页
幼儿
文学
社科
教辅
生活
销量榜
TYPESCRIPT实战指南
TypeScript实战指南(零基础入门,实战案例详解)
装帧: 平装
出版社: 机械工业出版社
作者: 胡桓铭 著
出版日期: 2019-05-01
商品条码: 9787111626701
版次: 1
开本: 16开
页数: 257
出版年份: 2019
定价:
¥89
销售价:
登录后查看价格
¥{{selectedSku?.salePrice}}
库存:
{{selectedSku?.stock}}
库存充足
{{item.title}}:
{{its.name}}
加入购物车
立即购买
加入书单
收藏
精选
¥5.83
世界图书名著昆虫记绿野仙踪木偶奇遇记儿童书籍彩图注音版
¥5.39
正版世界名著文学小说名家名译中学生课外阅读书籍图书批发 70册
¥8.58
简笔画10000例加厚版2-6岁幼儿童涂色本涂鸦本绘画本填色书正版
¥5.83
世界文学名著全49册中小学生青少年课外书籍文学小说批发正版
¥4.95
全优冲刺100分测试卷一二三四五六年级上下册语文数学英语模拟卷
¥8.69
父与子彩图注音完整版小学生图书批发儿童课外阅读书籍正版1册
¥24.2
好玩的洞洞拉拉书0-3岁宝宝早教益智游戏书机关立体翻翻书4册
¥7.15
幼儿认字识字大王3000字幼儿园中班大班学前班宝宝早教启蒙书
¥11.55
用思维导图读懂儿童心理学培养情绪管理与性格培养故事指导书
¥19.8
少年读漫画鬼谷子全6册在漫画中学国学小学生课外阅读书籍正版
¥64
科学真好玩
¥12.7
一年级下4册·读读童谣和儿歌
¥38.4
原生态新生代(传统木版年画的当代传承国际研讨会论文集)
¥11.14
法国经典中篇小说
¥11.32
上海的狐步舞--穆时英(中国现代文学馆馆藏初版本经典)
¥21.56
猫的摇篮(精)
¥30.72
幼儿园特色课程实施方案/幼儿园生命成长启蒙教育课程丛书
¥24.94
旧时风物(精)
¥12.04
三希堂三帖/墨林珍赏
¥6.88
寒山子庞居士诗帖/墨林珍赏
¥6.88
苕溪帖/墨林珍赏
¥6.88
楷书王维诗卷/墨林珍赏
¥9.46
兰亭序/墨林珍赏
¥7.74
祭侄文稿/墨林珍赏
¥7.74
蜀素帖/墨林珍赏
¥12.04
真草千字文/墨林珍赏
¥114.4
进宴仪轨(精)/中国古代舞乐域外图书
¥24.94
舞蹈音乐的基础理论与应用
编辑推荐
本书从应用角度出发,手把手教你学习TypeScript,包含大量实战案例代码与开发技巧,可帮助读者快速掌握TypeScript的开发。
内容简介
本书深入浅出地介绍TypeScript基础知识和开发技巧,可帮助读者快速入门并掌握TypeScript的开发。本书分为基础篇和实战篇,共11章。基础篇包括:TypeScript的类型与函数、接口与类、命名空间与模块。实战篇详细介绍如何在各种前端项目中应用TypeScript,包括命令行实战、Express实战,以及在React、React Native、Vue、微信小程序等项目中如何应用TypeScript,*后还介绍了项目迁移与社区共建等。
作者简介
胡桓铭 前端开发者,曾任ThoughtWorks前端工程师,参与过多个项目的开发与部署,对TypeScript情有独钟,参与了TypeScript的DefinitelyTyped部分维护。
目录
前言基础篇第1章 Hello TypeScript 21.1 引言 21.1.1 JavaScript 与 ECMAScript 31.1.2 TypeScript 51.2 准备环境 81.2.1 安装 Node.js 81.2.2 npm和 Yarn 91.2.3 安装 TypeScript 101.3 Visual Studio Code 111.3.1 安装VSCode 111.3.2 安装Shell 命令 121.4 Hello World 121.5 本章小结 141.6 作业 14第2章 类型与函数 152.1 基本类型 152.1.1 JavaScript 的基本类型 162.1.2 TypeScript的基本类型 162.1.3 变量声明 182.1.4 泛型 192.1.5 枚举 222.1.6 symbol 252.1.7 iterator和generator 262.2 高级类型 312.2.1 interface 312.2.2 交叉类型与联合类型 322.2.3 类型保护与区分类型 352.2.4 typeof 与 instanceof 382.2.5 类型别名 402.2.6 字面量类型 412.2.7 索引类型与映射类型 412.2.8 类型推导 442.3 函数 482.3.1 定义函数 482.3.2 参数 492.3.3 回调函数和 promise 522.3.4 async 和 await 592.3.5 重载 592.4 本章小结 612.5 作业 61第3章 接口与类 633.1 接口 633.1.1 定义 643.1.2 函数类型 693.1.3 可索引类型 703.1.4 继承接口 713.2 类 723.2.1 定义 733.2.2 实现接口 733.2.3 继承 743.2.4 存取器 763.2.5 只读属性 773.2.6 类函数和静态属性 783.2.7 抽象类 783.3 本章小结 803.4 作业 80第4章 命名空间与模块 814.1 命名空间 814.1.1 单文件命名空间 814.1.2 多文件命名空间 834.1.3 别名 844.1.4 外部命名空间 854.2 模块 864.2.1 导出与导入 874.2.2 生成模块 914.2.3 外部模块 944.3 本章小结 974.4 作业 97实战篇第5章 命令行应用实战:天气查询 1065.1 创建项目 1065.1.1 初始化项目 1085.1.2 配置 TSConfig 1095.1.3 配置 TSLint 1125.1.4 使用 Git 1135.2 Commander.js 1175.2.1 格式化命令 1185.2.2 更好的输入 1205.2.3 添加色彩 1225.3 处理网络请求 1235.3.1 定义接口 1235.3.2 Promise 1255.3.3 await 和 async 1275.4 本章小结 1285.5 作业 128第6章 Express实战:后端服务 1296.1 创建项目 1296.1.1 初始化项目 1306.1.2 Husky 1316.2 定义数据结构 1326.2.1 连接数据库 1336.2.2 定义数据模型 1346.3 数据接口 1356.3.1 Express 1366.3.2 增删查改 1376.4 本章小结 1426.5 作业 143第7章 React 实战:桌面网站 1447.1 创建项目 1447.1.1 create-react-app 1457.1.2 配置 TypeScript 1477.1.3 配置 TSLint 1567.2 架构 1587.2.1 React-Router 1587.2.2 Redux 1607.3 编辑提醒事项 1637.3.1 组件 1647.3.2 Redux 组件 1667.3.3 Redux Persist 1707.3.4 处理网络请求 1747.4 实现列表 1807.4.1 实现列表页 1807.4.2 复用编辑组件 1827.5 测试 1907.5.1 配置 Jest 1907.5.2 组件的测试 1927.5.3 Action 的测试 1957.5.4 Reducer的测试 1967.6 本章小结 1977.7 作业 198第8章 React Native 实战:客户端开发 1998.1 创建项目 1998.1.1 配置开发环境 2008.1.2 创建 React Native 项目 2088.2 设计架构 2108.2.1 React Navigation 2118.2.2 Reudx 2128.2.3 列表页 2158.3 本章小结 2178.4 作业 217第9章 Vue 实战:HTML 5网页开发 2199.1 创建项目 2199.1.1 创建 Vue 项目 2209.1.2 写TypeScript代码 2219.2 实现列表 2259.2.1 vue-class-component 2259.2.2 网络请求 2289.2.3 列表页 2309.3 本章小结 2319.4 作业 231第10章 小程序实战 23410.1 创建项目 23410.1.1 创建小程序 23610.1.2 创建 WePY 工程项目 23910.1.3 配置 TypeScript 24110.1.4 入口文件 24210.1.5 WePY页面 24310.1.6 WePY组件 24610.1.7 针对原生API进行优化 24610.2 实现列表 24710.2.1 网络请求 24710.2.2 列表页 24910.3 本章小结 24910.4 作业 250第11章 项目迁移与社区共建 25111.1 项目迁移 25111.1.1 从 JavaScript 迁移到TypeScript 25211.1.2 从 Flow迁移到TypeScript 25311.2 社区共建 25411.2.1 贡献类型文件 25411.2.2 关注更新 25611.3 本章小结 25711.4 作业 257
摘要
与 TypeScript相遇,还是在 ThoughtWorks 工作的时候。那个时候,我们需要维护大量的前端遗留项目,需要与客户规划我们的人效,需要控制系统迭代带来的 bug 率。我们接手的项目往往缺乏严谨的注释和完整的代码说明文档,这导致在维护 JavaScript 遗留项目时,需要花费更多的时间去厘清参数及函数之间的关系,甚至需要用 debugger 逐层去观察值的变化。工作非常低效,但客户的需求又总是急迫的,这迫使我们去思考如何提升团队的工作效率。这个时期也是 Facebook 开始推广Flow 的时候。我们觉得添加静态类型应该是个非常不错的方向,也看了很多应用静态类型的成功案例。碰巧Flow 对于遗留项目非常友好,你不需要为每个文件、每个函数、每行代码都添加类型,而只需要在你认为有必要的地方写上类型即可。所以我们很快进行了实验。然而,我们在采用 Flow后不久就发现了很多新产生的问题:1)升级困难,配置复杂。尤其是在 React Native 项目中,经常会在升级后运行失败。2)生态弱势。很多第三方库当时没有 Flow 的类型问题件。3)难于上手。Flow 的气质更像考究的学院派风格,功能强大灵活,但对于新加入团队的人而言,其难度令人生畏。于是,我们又将目光投向了 TypeScript。最初了解 TypeScript是看到Angular 团队在更新 Angular 2 时开始全面采用TypeScript 代码。他们给出了这样两个理由:1)TypeScript 明确了抽象。在大型工程项目中,我们希望模块之间的边界是使用接口定义的,而 JavaScript 不足以清晰表达类似的边界划分,Flow也不能。而 TypeScript 可以定义接口,可以强制程序员去思考 API 的边界,去设计代码,而不只是编写代码,暴露代码的耦合。2)TypeScript 可以使代码在一定程度上达到“Self-documenting” 的效果。“Self-documenting”是一个非常有意思的概念,它强调的是代码本身具有自我说明的效果,而不是依赖文档。TypeScript 有着非常严格的强类型表达,这迫使你在函数使用之前就必须标注好函数的入参和返回值类型。这样的强依赖使得函数本身表达清晰,同时也可以非常容易地推导出代码的依赖结构,进行重构。之后,我们开始尝试在遗留项目中进行TypeScript重构,那是一种相见恨晚的感觉。从后期的数据来看,我们很有效地降低了bug率,同时支持项目的人效也得到了极大的提升。这一段经历,使我重新开始思考关于语言静态类型的问题。在大型团队开发时,沟通的成本往往是极高的。这就是为什么在后端开发中,拥有静态类型的语言仍然占据主流,也是为什么Python在3.5版本中加入Type Hint。显式的类型声明不仅有利于阅读,也有利于代码编辑器进行代码提示和依赖分析。比如,在Java开发中,如果需要重构的话,依赖IntelliJ IDEA提供的函数重构功能,可以自动地对每一个依赖该函数的文件进行自动化重构。但这在JavaScript中是不可想象的,你只能使用全局文本搜索来修改函数名,这种操作非常原始,就像在现代战争中还拿着石锤向着敌方阵地冲刺一样。这就是TypeScript为JavaScript生态带来的价值,也是为什么Angular和Vue都转向使用TypeScript进行重构。比起学术型的Flow而言,TypeScript更像一门工程型的语言,它配置容易,上手快速,更适合在实战中使用,是一件非常称手的“兵器”。我希望读者在使用TypeScript之前,能够对TypeScript有足够的了解。我结合TypeScript的官方手册与其他公开资料,整理了一些TypeScript基础的内容,就是本书的“基础篇”,最好粗略过一遍这部分内容。在“实战篇”中会提及这些内容,返回去再看时,反而能加深理解。实际上,如何在实战中使用TypeScript反而是一个老大难的问题。这也是初学者更容易遇到的困难。“为什么手册读完了,官方实例也看了,我还是不会在React里写TypeScript呢?”这是我经常听到的反馈,希望本书能够很好地回答这类问题。最后,非常感谢2018年年底的住院经历,因为无法完全被治愈,使得我开始重新思考生命与健康的问题,如果有机会我也非常想聊聊这个话题。我非常感谢娜娜的陪伴,这是最长情的告白。同时感谢吴怡编辑的理解与体谅,使得我还有机会完成此书。最后感谢开源社区,不仅帮助我成长,也提供了丰富的资料助力我完成此书,希望能有更多的机会回馈社区。作者于2019年元宵节
×
Close
添加到书单
加载中...
点此新建书单
×
Close
新建书单
标题:
简介:
蜀ICP备2024047804号
Copyright 版权所有 © jvwen.com 聚文网