编辑推荐

适读人群:需要在Windows、OSX和Linux上应用NW.js和Electron构建桌面程序系统的开发人员。

传统桌面应用开发要求懂高级编程语言以及专门的框架。有了Electron和NW.js,你可以将现有Web开发技术运用到仅仅使用HTML、CSS和JavaScript就能开发的桌面应用中。而且,开发出来的应用还能在Windows、Mac和Linux中工作,显著减少了开发和培训的时间。

跨平台桌面应用开发:基于Electron与NW.js》一步步指导你使用Electron和NW.js来进行桌面应用开发。这份指导中包含了大量的示例,教你如何开发一个属于你自己的文件浏览器,介绍使用框架提供的API来访问摄像头、剪贴板数据,制作可以用键盘控制的游戏以及构建一个Twitter桌面提醒工具。你还会学到如何测试和调试应用,以及为不同操作系统将应用打包为二进制文件。

跨平台桌面应用开发:基于Electron与NW.js》包含的内容

□使用桌面摄像头创建一个自拍应用

□学习如何使用Devtron来测试Electron应用

□学习如何在你的应用中使用Node.js

内容简介

跨平台桌面应用开发:基于Electron与NW.js》是一本同时介绍Electron和NW.js的图书,这两者是目前流行的支持使用HTML、CSS和JavaScript进行桌面应用开发的框架。书中包含大量的编码示例,而且每个示例都是五脏俱全的实用应用,作者对示例中的关键代码都做了非常详细的解释和说明,可让读者通过实际的编码体会使用这两款框架开发桌面应用的切实感受。除此之外,在内容上,《跨平台桌面应用开发:基于Electron与NW.js》非常系统,分为4大部分:第1部分介绍两个框架的历史背景,并教大家编写**个桌面应用,让读者对这两个框架有一个初步的感受;第2部分深入讲解NW.js和Electron的内部工作原理,帮助大家剖析这两个框架的底层机制,让读者对它们有更深入的理解;第3部分介绍使用框架提供的大量API来构建多款实用的桌面应用,全方位地让读者体会使用这两个框架开发桌面应用带来的舒适体验;第4部分为大家讲解了,当开发完成后,如何对应用进行测试、跨平台打包和发布。可以说这4部分结合起来将开发桌面应用的整个流程系统化地讲解得非常清楚、到位。相信结合书中大量的示例,读者一定能很快掌握并自己使用Electron和NW.js构建出跨平台的桌面应用。

作者简介

PaulJensen是英国伦敦一家名为Starcount公司的高级售前顾问。他曾在创业公司工作过,网路代理商NewBamboo(现在属于Thoughtbot),AOL,以及他自己的咨询公司,AnephenixLtd。他在一些大会(伦敦Ruby用户组,2013年的Cukeup以及伦敦用户组)上做过演讲,创建了他自己的实时仪表盘(Dashku),也曾是web框架Socketstream的项目带头人。他喜欢麦芽酒和骑行,他的推特账号是:@paulbjensen。
跨平台桌面应用开发:基于Electron与NW.js》译者中英文水平都极高,且工作在编程第一线,具有丰富的理论知识和实践经验,此前翻译过图书,相信能为大家带来一本质量上乘的图书。

精彩书评

跨平台桌面应用开发:基于Electron与NW.js》适合了解HTML、CSS和JavaScript的开发者。

——PaulJensen就职于Starcount,生活在英国伦敦。

你会被这么容易就能开发桌面应用而感到震惊的!

——赵成,Electron的创造者

“一次编写,到处运行”,真的成真了。

——StephenByrne,Dell

目录

第1部分欢迎来到.Node.js.桌面应用开发的世界
第1章Electron和NW.js入门.3
1.1为什么要用.Node.js.构建桌面应用.4
1.1.1桌面应用到.Web.应用,再回到桌面应用.4
1.1.2Node.js.桌面应用相比.Web.应用有什么优势.6
1.2NW.js.和.Electron.的起源.8
1.3NW.js.介绍.9
1.3.1使用.NW.js.构建.Hello.World.应用.10
1.3.2NW.js.有哪些特性.15
1.4Electron.介绍.18
1.4.1Electron.是如何工作的以及它和.NW.js.的区别是什么.19
1.4.2使用.Electron.开发.Hello.World.应用.19
1.4.3Electron.有哪些特性.25
1.5NW.js.和.Electron.支持创建哪类应用.25
1.5.1Slack.26
1.5.2Light.Table.26
1.5.3Game.Dev.Tycoon.27
1.5.4Gitter.28
1.5.5Macaw.29
1.5.6Hyper.30
1.6小结.31

第2章为你的首款桌面应用搭建基础架构.32
2.1我们将构建什么应用.33
2.2创建应用.34
2.2.1安装.NW.js.和.Electron.34
2.2.2为.NW.js.版本的应用创建文件和文件夹.35
2.2.3为.Electron.版本的应用创建文件和文件夹.37
2.3实现启动界面.39
2.3.1在工具条中展示用户个人文件夹信息.40
2.3.2显示用户个人文件夹中的文件和文件夹.44
2.4小结.54

第3章构建你的首款桌面应用.56
3.1浏览文件夹.57
3.1.1重构代码.57
3.1.2处理对文件夹的双击操作.61
3.2实现快速搜索.64
3.2.1在工具条中增加搜索框.65
3.2.2引入一个内存搜索库.65
3.2.3在界面上触发搜索功能.67
3.3改进应用内的导航功能.71
3.3.1实现当前文件夹路径可单击.71
3.3.2让应用随着文件夹路径的改变显示对应的文件夹内容.74
3.3.3实现使用默认应用打开对应的文件.75
3.4小结.77

第4章分发你的首款桌面应用.79
4.1对应用进行与分发相关的设置.80
4.2对要分发的应用进行打包.83
4.2.1使用一种.NW.js.的构建工具.83
4.2.2使用一种.Electron的构建工具.84
4.2.3设置应用的图标.85
4.3在多个操作系统中测试应用.91
4.3.1Windows.操作系统.91
4.3.2Linux.操作系统.92
4.3.3Mac.OS.系统.92
4.4小结.92

第2部分深度剖析
第5章在NW.js和Electron中使用Node.js.97
5.1什么是.Node.js.98
5.1.1同步与异步.98
5.1.2流是一等公民.101
5.1.3事件.105
5.1.4模块.106
5.2Node.包管理器.109
5.2.1寻找应用需要的模块.109
5.2.2使用.package.json记录安装的模块.109
5.2.3使用.npm.打包模块和应用.111
5.3小结.114

第6章探索NW.js和Electron的内部机制.115
6.1NW.js.内部是如何工作的.116
6.1.1使用同一个.V8.实例.117
6.1.2集成主事件循环.118
6.1.3桥接.Node.js.和.Chromium.的.JavaScript.上下文.119
6.2Electron.内部是如何工作的.119
6.2.1libchromiumcontent.介绍.120
6.2.2Electron.中的组件.120
6.2.3Electron.是如何将应用运行起来的.121
6.3Node.js是如何与NW.js以及Electron一起工作的.122
6.3.1Node.js.集成在.NW.js.的哪个位置.122
6.3.2在.NW.js中使用.Node.js.的缺点.123
6.3.3Electron.是怎么使用.Node.js.的.123
6.4小结.124

第3部分精通Node.js桌面应用开发
第7章自定义桌面应用的外观.127
7.1视窗的尺寸和模式.127
7.1.1配置.NW.js.应用的视窗尺寸.128
7.1.2配置.Electron.应用的视窗尺寸.129
7.1.3在.NW.js.中限制视窗的尺寸.131
7.1.4在.Electron.中限制视窗的尺寸.133
7.2无边框应用以及全屏应用.134
7.2.1NW.js.中的全屏应用.135
7.2.2Electron.中的全屏应用.138
7.2.3无边框应用.140
7.2.4kiosk.应用.145
7.3小结.149

第8章创建托盘应用.150
8.1使用.NW.js.创建简单的托盘应用.151
8.2使用.Electron.创建托盘应用.156
8.3小结.159

第9章创建应用菜单以及上下文菜单.161
9.1为应用添加菜单.162
9.1.1应用视窗菜单.162
9.1.2使用.NW.js.为.Mac.OS的应用创建菜单.162
9.1.3使用.Electron.为.Mac.OS的应用创建菜单.163
9.1.4为.Windows.和.Linux的应用创建菜单.166
9.1.5基于操作系统来选择渲染具体的菜单.173
9.2上下文菜单.174
9.2.1使用.NW.js.创建上下文菜单.174
9.2.2NW.js.中的上下文菜单是如何工作的.179
9.2.3设置菜单项图标.180
9.2.4使用.Electron.创建上下文菜单.181
9.2.5使用.Electron.添加上下文菜单.184
9.3小结.185

第10章拖曳文件以及定制界面.186
10.1在应用中拖曳文件.186
10.1.1使用.NW.js.实现在应用中拖曳文件.187
10.1.2使用.Electron.实现拖曳功能.190
10.2模拟操作系统原生样式.191
10.2.1检测用户的操作系统.191
10.2.2使用.NW.js检测操作系统.191
10.2.3使用.Electron检测操作系统.192
10.2.4使用.CSS匹配用户操作系统的样式.194
10.3小结.197

第11章在应用中使用网络摄像头.198
11.1使用.HTML5.媒体捕捉.API.来实现相片快照.198
11.1.1解读.NW.js.版的应用.199
11.1.2使用.Electron.构建.Facebomb.应用.205
11.2小结.210

第12章存储应用数据.211
12.1应该使用哪种数据存储方案.211
12.2使用.localStorage.API.存储便笺数据.212
12.2.1使用.Electron开发.Let.Me.Remember应用.213
12.2.2使用.NW.js开发.Let.Me.Remember应用.216
12.3将待办事项应用移植为桌面应用.219
12.3.1使用.NW.js.移植.TodoMVC.Web.应用.219
12.3.2使用.Electron.移植.TodoMVC.应用.220
12.4小结.222

第13章从剪贴板复制和粘贴数据.223
13.1访问剪贴板数据.223
13.1.1使用.NW.js.创建.Pearls.应用.224
13.1.2使用.Electron.创建.Pearls.应用.228
13.1.3使用.Electron.将不同类型的数据写入剪贴板.231
13.2小结.232

第14章绑定键盘快捷键.233
14.1使用.NW.js.创建贪吃蛇游戏.234
14.1.1使用.NW.js.在视窗获取焦点的时候实现键盘快捷键.242
14.1.2使用.NW.js.来创建全局键盘快捷键.243
14.2使用.Electron.为贪吃蛇游戏创建全局快捷键.245
14.3小结.247

第15章制作桌面通知.248
15.1关于你要构建的应用.249
15.2使用.Electron.构建.Watchy.应用.249
15.3使用.NW.js.构建.Watchy.应用.254
15.4小结.257

第4部分准备发布
第16章测试桌面应用.261
16.1测试应用的不同方法.262
16.1.1测试驱动开发.262
16.1.2行为驱动开发.264
16.1.3不同层面的测试.265
16.2单元测试.265
16.2.1使用.Mocha.编写测试.266
16.2.2让待完成的测试变成执行通过的测试.268
16.3功能测试.271
16.3.1功能测试实践.272
16.3.2使用.NW.js.和.ChromeDriver.进行测试.272
16.4使用Spectron测试Electron应用.273
16.5集成测试.275
16.5.1Cucumber.介绍.276
16.5.2使用.Cucumber和.Spectron对.Electron应用进行自动化测试.277
16.6小结.280

第17章调试并提升应用性能.281
17.1了解你要调试的是什么.282
17.1.1确定问题根本原因的位置.283
17.1.2使用浏览器开发者工具进行调试.284
17.2修复.bug.287
17.2.1使用.Node.js.的调试器来调试应用.288
17.2.2使用.NW.js.的开发者工具来调试应用.291
17.3解决性能问题.296
17.3.1Network选项卡.296
17.3.2Timeline选项卡.297
17.3.3Pro.les选项卡.299
17.4调试.Electron.应用.301
17.5小结.307

第18章为多平台打包应用.308
18.1为应用创建可执行文件.309
18.1.1为.Windows.系统创建.NW.js.应用的可执行文件.309
18.1.2安装虚拟机.309
18.1.3为一个.NW.js应用创建针对.Windows系统的.exe文件.310
18.1.4为一个.Electron.应用创建.Windows.系统的可执行文件.311
18.2为.Windows.的应用创建启动安装器.314
18.2.1使用.NW.js.创建.Windows.系统启动安装器.314
18.2.2使用.Electron创建.Windows系统启动安装器.321
18.3为.Mac.OS.创建.NW.js.应用的可执行文件.324
18.3.1创建.Mac.可执行应用.324
18.3.2为.Mac.OS.创建.Electron.应用的可执行文件.327
18.4为.Linux.创建可执行应用.329
18.4.1为.Linux.创建独立的.NW.js.应用文件.330
18.4.2为.Linux.创建独立的.Electron.应用文件.331
18.5小结.333
附录A安装.Node.js.335

前言/序言

译者序

StackOver.ow的联合创始人JeffAtwood说过一句非常经典的话:AnyapplicationthatcanbewritteninJavaScript,willeventuallybewritteninJavaScript,翻译过来就是:任何能使用JavaScript来编写的应用,最终都会用JavaScript来实现。这句话被誉为Atwood定律。事实上,这句话正在不同领域被一次一次地验证。以前JavaScript只是运行在浏览器沙箱环境中的脚本语言,而自从2009年Node.js问世后,JavaScript在服务器端、物联网领域、移动原生应用开发领域,乃至桌面应用开发领域都大放异彩。

以往要开发桌面应用,针对Windows、Linux以及MacOS三大平台要专门去学习各自平台的编程语言和框架,成本高昂而且要做一款支持兼容三种平台的桌面应用非常费时,基本都需要针对不同平台的不同团队才能实现。就我个人而言,几年前我一直想学习Objective-C以及Cocoa来开发MacOSX桌面应用,但是始终没有成功。现如今,JavaScript让这一切都变得无比简单。一名Web开发者就能开发出兼容三大操作系统的桌面应用。不仅大大降低了学习曲线,而且开发效率可以说呈指数级提升。这要归功于NW.js和Electron这两款目前最流行的使用Web技术开发桌面应用的开发框架。这两款框架将Chromium和Node.js非常好地结合起来,Chromium使得Web开发技术能够在桌面应用中得以施展,Node.js则提供了访问操作系统API的能力,两者的结合使得使用JavaScript开发桌面应用成为可能。

目前,NW.js和Electron这两款框架在全世界各大公司被广泛使用。近几年红遍全球的Slack就是使用Electron来开发他们的桌面应用的,国内阿里巴巴的企业应用—钉钉桌面应用,就是用NW.js来开发的,除此之外,全球范围内越来越多的桌面应用都在采用这两种框架进行开发。

跨平台桌面应用开发:基于Electron与NW.js》是一本专门介绍如何使用NW.js和Electron框架来开发桌面应用的书。在国内,目前《跨平台桌面应用开发:基于Electron与NW.js》应该是第一本同时介绍NW.js和Electron开发桌面应用的图书。而且《跨平台桌面应用开发:基于Electron与NW.js》内容非常系统,从框架的背景介绍、教你开发第一款桌面应用、深入剖析框架内部原理、通过丰富的示例应用介绍框架提供的多个API,再到应用的测试、调试、跨平台打包、构建和最终的发布,涵盖整个开发到发布流程中的所有环节。而且《跨平台桌面应用开发:基于Electron与NW.js》的每一章中都有大量的实用示例,通过实际的编码让你感受使用NW.js的Electron开发桌面应用的体验。书中每个示例应用都会分别介绍NW.js和Electron两个版本如何实现、过程中需要注意的地方有哪些,非常有实践价值。总的来说,《跨平台桌面应用开发:基于Electron与NW.js》不论是对于初学者还是有一定经验的开发者,都是一本相当好的学习使用NW.js和Electron开发桌面应用的图书。

最后,非常感谢电子工业出版社计算机出版分社的张春雨编辑对我的信任,将这《跨平台桌面应用开发:基于Electron与NW.js》交给我来翻译;感谢《跨平台桌面应用开发:基于Electron与NW.js》的责任编辑刘舫对《跨平台桌面应用开发:基于Electron与NW.js》的辛苦付出;还要感谢《跨平台桌面应用开发:基于Electron与NW.js》的原作者PaulB.Jensen,翻译过程中遇到模棱两可的地方,通过Twitter联系他,他都能及时回复我,并给予详细的解释。

翻译和写书一样,都是需要花费大量精力和时间的事情,自从翻译完上一本《了不起的Node.js》后,我就对自己说我再也不会干翻译图书的事情了,实在是太累了。但是,当出版社编辑找到我,给我看了原版样书后,我还是没忍住,因为虽然过程很累很苦,但是在书出版的那一刻,除了自己小小的虚荣心能够得到一点满足,更多的是一想到可以帮助到很多学习使用NW.js和Electron开发桌面应用的开发者,就觉得非常自豪,再累再苦都是值得的!当然,翻译过程中难免会有错误的地方,也希望大家能够多多指正!

谨以此书献给在背后默默支持我的家人,特别是我的两个孩子—木木和一一,希望你们能够健康快乐地成长,爸爸爱你们!

GoddyZhao2017年12月12日于上海

推荐序

Electron框架诞生于2013年,那个时候Node.js才刚刚流行起来。整个社区因JavaScript能够在客户端和服务器端运行而兴奋不已,并且也在尝试使用JavaScript来开发桌面应用。

我个人也对JavaScript技术很热衷,而且GUI编程是我比较喜欢的领域。我自己写过一些Node.js的模块,这些模块对主流的GUI工具提供了JavaScript的绑定,不过都做得一般,也没有引起太多关注。

之后我发现了一个非常有趣的Node.js模块,叫作node-webkit:这个简单的模块可以实现在WebKit浏览器中插入执行Node.js代码。于是我有了一个点子,可以用它来开发一个具备完整功能的客户端开发框架:我可以用Chromium来显示Web页面,就像桌面窗口一样,然后其他的都用Node.js来控制!

当时node-webkit的开发并不活跃,于是我接手了这个项目并进行重写,将它打造成一个完善的用于桌面应用开发的框架。当我完成第一版的时候,它可以用于开发小型的跨平台应用,效果奇好!

与此同时,GitHub正在秘密开发一款基于Web技术的Atom编辑器,而且他们非常希望可以有一个更好的工具来替代目前Atom不尽如人意的Web运行时。GitHub曾尝试将Atom迁移到node-webkit,但是遇到了很多问题。我和他们的开发者碰了面并且最终我们达成一致:由我来开发一款新的框架,让开发者使用Node.js

技术和浏览器相关技术就可以开发桌面程序,然后再帮他们把Atom迁移过来。

这款新的框架起初命名为atom-shell;一年后,在正式开源的时候将其改名为Electron。Electron是从零开始开发的,并且使用了和node-webkit完全不同的底层架构,它可以让开发者开发大型且复杂的桌面端应用。(如今,node-webkit交由其他开发者在维护开发,项目状态也比较活跃。它现在叫NW.js,使用也很广泛。)

因为使用Electron可以既简单又快速地构建出复杂的跨平台应用,所以它得到了许多开发者的关注,发展也很迅速。现如今,许多大公司都基于Electron开发了他们的桌面端产品,除此之外,小型创业公司也围绕这个平台在构建他们的业务。

使用Electron和NW.js开发桌面应用要求开发者掌握一些新的概念。桌面应用开发和前端程序开发截然不同,对于初学者来说也更难。不过《跨平台桌面应用开发:基于Electron与NW.js》可以帮助到大家。

跨平台桌面应用开发:基于Electron与NW.js》将带你一览Electron和NW.js丰富的API、教你如何开发桌面应用。你会学到许多使用JavaScript开发桌面应用的技术细节,包括如何构建和分发应用,以及如何将现有应用集成到桌面应用中的一些深度小技巧。《跨平台桌面应用开发:基于Electron与NW.js》还涵盖了一些高级话题,如调试、分析以及在不同平台发布应用,哪怕是有经验的开发者也可以从中学到不少东西。

我建议所有想要开发桌面应用的读者都来阅读《跨平台桌面应用开发:基于Electron与NW.js》。读完后你会惊讶于使用JavaScript和Web技术来进行跨平台的桌面应用开发是一件多么简单的事情。

ChengZhaoElectron框架开发者

序言

几年前我在一家叫AxistoMedia的公司工作时,我们需要为一个健康行业大会开发一款桌面应用,用来展示大会的视频、议题信息以及海报。当时这款应用是用AdobeAIR开发的。但是开发过程并不容易,而且客户需要进行一些操作才能让应用在他们的计算机中运行起来。好在我们后来找到了更好的解决方案。

我大概从2013年年底开始学习NW.js(那个时候它叫node-webkit)。我发现使用NW.js开发的桌面应用客户用起来更方便,因为他们不再需要安装AdobeFlash播放器,也不用把应用文件放到U盘里来加载。他们只需双击应用就可以运行了。不仅如此,我们还能提供Linux版本,而且其技术栈和我们的业务本身的技术栈很契合,因为我们在其他地方也都使用Node.js技术。

我抓住了机会,使用NW.js去重新构建这款桌面应用并且摒弃一切,勇往直前。NW.js让一切都变得更加简单,这得益于它可以从大会网站的Web应用重用HTML、CSS和JS代码,我们可以让桌面应用看上去样式更加统一。这是一个巨大的好处。

我当时对这个框架非常满意,于是决定在2014年6月的伦敦Node.js用户组聚会上进行分享。后来我就把演示稿放到了网上。几个月后,我发现这个演示稿在SlideShare网站上很快被查看了20000次。这太棒了,我以为这事就这样了。

然而并没有。

2014年12月,我收到了一封来自Manning出版社ErinTwohey的电子邮件,他问我是否有兴趣写一本关于node-webkit的书。这简直太棒了,我立刻就投入到这《跨平台桌面应用开发:基于Electron与NW.js》的写作中。

那段时间发生了很多事情。Node.js社区fork了Node.js项目并命名为IO.js,他们加快了平台新特性的开发,后来IO.js项目又合并回了Node.js项目。node-webkit框架切换到了IO.js,并且由于它使用了Blink而非WebKit,因此改名为NW.js。一年过去了,《跨平台桌面应用开发:基于Electron与NW.js》的写作也临近尾声,就在这个时候,我们发现了另外一个可以用Node.js开发桌面应用的框架,叫Electron。仔细一看,我发现Electron和NW.js很像,而且它的作者以前就是开发NW.js的。于是我们决定将Electron也写到《跨平台桌面应用开发:基于Electron与NW.js》中。

写一《跨平台桌面应用开发:基于Electron与NW.js》同时涵盖两种Node.js桌面应用开发框架是一个挑战,不过最终还是完成了。《跨平台桌面应用开发:基于Electron与NW.js》涵盖了使用NW.js和Electron开发桌面应用的基础知识。尽管《跨平台桌面应用开发:基于Electron与NW.js》没有面面俱到地介绍这两个框架,但是足够让你了解它们的大部分特性以及如何使用的知识,这样你就可以根据你的需求,选择其中一个框架来构建桌面应用。

对于开发者来说这是一个很好的时代,有了像NW.js和Electron这样的工具,构建桌面应用变得再简单不过。我希望你喜欢这《跨平台桌面应用开发:基于Electron与NW.js》,如果对于这两个框架有问题想问我的话,可以通过我的电子邮箱paulbjensen@gmail.com或者通过我的Twitter账号@paulbjensen联系我。

PaulB.Jensen

致谢

写书是非常艰难的项目之一,它需要投入大量的时间和精力。同时,还需要不少人的协助。我要感谢的人很多,他们都或多或少帮助过我。首先我要感谢Manning出版社负责《跨平台桌面应用开发:基于Electron与NW.js》的团队:ErinTwohey、AnaRomac、CandaceGillhoolhey、RebeccaRinehart、AleksandarDragosavljevic、ToniBowers、

ˊMehmedPasic、KarenGulliver、KatieTennant、JanetVail以及LynnBeighley。促成《跨平台桌面应用开发:基于Electron与NW.js》的工作量之大是你难以想象的,在此过程中他们都极力帮助我完善《跨平台桌面应用开发:基于Electron与NW.js》。我还要感谢技术审校CliveHarber和以下这些审校人员:AngeloCosta、DanielBaktiar、DarkoBozhinovski、DeepakKaranth、FernandoMonteiroKobayashi、JeffSmith、MattBorack、NicolasBoulet-Lavoie、OlivierDucatteeuw、PatrickRegan、PatrickRein、RobertWalsh、RocioChongtay、StephenByrne、ToniLa..hdekorpi、WilliamWheeler、YogeshPoojari以及MarceloPires;同时感谢NatkoStipanicˇev在图片方面提供的帮助。

感谢MarjanBace给我写作《跨平台桌面应用开发:基于Electron与NW.js》的机会。能为Manning写书是一种荣誉;我的书架上有不少Manning出版社的书,现在他们的书架上多了一本我的书。还要感谢MichaelStephens在写书之初帮助我制订了《跨平台桌面应用开发:基于Electron与NW.js》的大纲、感谢他在面对我各种拖稿的时候能够妥善处理、感谢他当我遇到个人困难的时候给予理解。

感谢我的开发编辑—CynthiaKane。她完成了最困难的工作—激励我完成每一个章节的内容。这是我的第一《跨平台桌面应用开发:基于Electron与NW.js》,你可以想象这个过程有多么痛苦。我有一份电子邮件归档,里面包含超过150封邮件,这些都是她在我写书阶段发给我的,那个时候我在伦敦、阿姆斯特丹、爱尔兰、意大利、纽约,然后又到阿姆斯特丹,最后又回到伦敦。在非常困难的2016年,Cynthia始终耐心地激励我将《跨平台桌面应用开发:基于Electron与NW.js》完成,而且尽管有时区问题,她都能及时地提供支持和帮助。万分感激,谢谢Cynthia。

感谢RogerWang和ChengZhao开发了NW.js和Electron—没有他们的努力,这《跨平台桌面应用开发:基于Electron与NW.js》压根就不可能存在。

感谢在伦敦Starcount的EdwinaDunn和CliveHumby,很荣幸可以和他们共事,非常感激他们给予我的支持。

感谢PurpleSeven的StuartNicolle。Stuart当年带我入职并带我领略了如何从艺术和戏剧分析世界中收集有用的信息。

感谢我的家人:我的母亲Jette、妹妹Maria和她的伙伴Mark,已故的GranLis以及Brenda和Jim。他们抚育我成人、在我人生道路上为我披荆斩棘。

我还想特别感谢Fiona。她容忍了我写书过程中的一切,甚至更多。《跨平台桌面应用开发:基于Electron与NW.js》能够成功出版和她对我的支持和爱是分不开的。

最后我还想提一下我的父亲Wily,他是一名硬件和软件工程师,非常聪明却又不好相处。虽然我们从未正眼看过对方,但还是要感谢有这样一位父亲。

关于代码

跨平台桌面应用开发:基于Electron与NW.js》包含诸多示例代码,有标明序号的多行代码,也有直接在正文中的单行代码。不论是哪种形式,代码都是以等宽字体的形式来表示的,以此来和正文进行区分。大多数情况下,源代码都是格式化过的;为了适应书页的空间添加了必要的换行和缩进。除此之外,当有专门解释源代码的文字时,代码注释通常就被去掉了。一般在多行代码以及高亮显示的重要概念时会有代码注解。

跨平台桌面应用开发:基于Electron与NW.js》中的示例代码可以通过出版社网站www.manning.com/books/cross-platform-desktop-applications或GitHub的http://github.com/paulbjensen/cross-platform-desktop-applications下载得到。

作者在线

购买《跨平台桌面应用开发:基于Electron与NW.js》之后,读者可以免费访问Manning出版社的私有论坛,在那里,可以对《跨平台桌面应用开发:基于Electron与NW.js》进行评论、提问技术问题,作者和论坛中的其他用户都会给予解答。要访问和订阅该论坛,请访问www.manning.com/books/cross-platform-desktop-applications。

读者服务

轻松注册成为博文视点社区用户(www.broadview.com.cn),扫码直达《跨平台桌面应用开发:基于Electron与NW.js》页面。

提交勘误:对书中内容的修改意见可在提交勘误处提交,若被采纳,将获赠博文视点社区积分(在你购买电子书时,积分可用来抵扣相应金额)。

与我们交流:在页面下方读者评论处留下疑问或观点,与我们和其他读者一同学习交流。

页面入口:http://www.broadview.com.cn/33474


其他推荐