用node-webkit把web应用打包成桌面应用

node-webkit是一个Chromium和node.js上的结合体,经过它咱们能够把创建在chrome浏览器和node.js上的web应用打包成桌面应用,并且还能够跨平台的哦。很显然比起传统的桌面应用,在某些特定领域用html5+css3+js开发的web应用更加简单和高效,并且还能够使用node.js的功能,因此node-webkit仍是颇有用处的。css

下面我经过一个简单的demo来介绍怎么样把一个web应用打包成一个可执行文件(这里只介绍windows环境)html

首先新建一个index.html文件,做为咱们这个demo的入口页面,咱们暂且就把这个页面当成一个完整的web应用吧。内容随便写点什么,好比:html5

QQ截图20140210135428

而后建立配置文件 package.json,内容以下:node

QQ截图20140210135428

其中的main属性就是用来指定入口文件的,这个属性的值能够是本地文件,也能够是远程网址,这样就至关于能够把一个远程的web应用直接变为一个桌面应用了。css3

除了name与main这两个属性外,还有不少其余有用的属性能够配置,好比指定应用的图标,显不显示浏览器的工具栏,指定浏览器的初始大小等等,具体的配置参数文档可看这里https://github.com/rogerwang/node-webkit/wiki/Manifest-formatgit

 

如今咱们有了两个文件了。github

QQ截图20140210135428

 

而后将index.html和package.json这两个文件压缩到一个zip压缩包里,命名为app.zipweb

QQ截图20140210135428

 

如今app.zip这个压缩包里的内容应该是这样的:chrome

QQ截图20140210135428

 

而后把app.zip这个文件的扩展名改成nw,变为 app.nwjson

QQ截图20140210135428

 

而后下载一个windows版本的node-webkit,解压后获得一个文件夹:

QQ截图20140210135428

 

以后咱们以前获得的app.nw这个文件就能够用nw.exe来执行了,直接把app.nw拖到nw.exe上就能够了。运行结果以下:

QQ截图20140210135428

跟在chrome中打开index.html这个页面的效果差很少,固然你能够经过配置package.json这个文件,来隐藏浏览器的工具栏或边框,来使它更像是一个桌面软件。

 

由于nw文件的运行须要node-webkit环境的支持,因此咱们还须要把app.nw这个文件跟node-webkit的环境文件一块儿打包成一个可执行文件。

首先打开windows的cmd,而后输入以下命令:

copy /b nw.exe+app.nw app.exe

注意文件路径要根据你的实际状况进行变更,这里假设app.nw放在了node-webkit的主文件夹里,而后输出的app.exe也会在这个文件夹里。

执行命令后咱们获得了 app.exe 这个可执行文件。

QQ截图20140210135428

 

到了这步,咱们已经获得了app.exe这个文件,但若是只有app.exe这个文件仍是不够的,这个可执行文件的运行还须要几个dll文件的支持。

其中 nw.pak 与 icudt.dll 这个两个文件是必需要的。

ffmpegsumo.dll 文件是媒体支持文件,若是你的html页面中用到了<video>或<audio>或其它与媒体相关的东西,则必须带上这个文件。

libEGL.dll 和 libGLESv2.dll 这个两个文件则是使用webGL或GPU必需要的

 

最后咱们获得的就是这样一个文件夹:

QQ截图20140210135428

执行app.exe就能够运行咱们的demo了。

 

但咱们大多数人想的是给用户一个exe文件,用户就能够使用了,不用再附带一些其余文件。

嗯,因此咱们还能够把app.exe跟其余的文件再打包一次,把上图中的全部文件变成一个可执行文件,用户只要获得这个文件,就能运行咱们的应用了。

作这步咱们须要一个软件叫Enigma Virtual Box,首先下载和安装这个软件,而后打开它。

而后在Enter Input File Name那里输入咱们的app.exe的路径,在Enter Output File Name那里填写咱们要把打包出来的可执行文件输出到哪里。最后是把除app.exe外的其它文件拖入到Files那里,遇到提示的话默认就能够了。

QQ截图20140210135428

 

最后点击右下角的Process按钮,就大功告成了。

QQ截图20140210135428

 

最后咱们获得了一个 app_boxed.exe 的文件,只要把这个文件交给用户,用户就能够运行了。

node-webkit虽然方便,但有个很大的缺点是获得的可执行文件有点大,你们在能够在衡量利弊后决定使不使用。

相关文章
相关标签/搜索