node.js 和HTML5开发本地桌面应用程序


Posted in Javascript onDecember 13, 2016

HTML5让Web开发人员用纯HTML技术开发富客户端互联网应用或者甚至本地桌面应用成为了可能。HTML5可以将任何普通网站转变成Web应用。HTML5 web 应用不仅具有在桌面浏览器应用中的优势,同时在智能手机和平板中也是开发利器。

在手机端,有一个非常棒的工具叫做PhoneGap,使用这个快速开发平台,任何人都可以使用HTML5+CSS3+JavaScript开发出安卓,iOS等应用。PhoneGap的最好的一个特点是,你并不需要联网,不需要连接web服务器,你可以从把它当成本地桌面应用。一旦下载到本地,它和本地原生应用一样可以离线使用。

通常我们会感觉网上有很多有趣的HTML应用,但这些应用非要你打开浏览器,输入网址。其实我们更喜欢直接点击桌面的一个图标就启动一个程序的这种体验。用HTML5+js开发的本地桌面应用就是要提高给用户这种体验,除了上面说的PhoneGap,还有一些像Pokki和Chrome Package Apps或Mozilla XUL Runner都是开发HTML5本地桌面应用的框架。

Pokki和Chrome不仅可以用来开发HTML5桌面应用,而且可以把这些应用放到交易市场中出售。

另外一个有趣的工具是Node-Webkit,本文下面内容主要讨论的将是它。

Node-Webkit是一个基于Chromium和Node.js运行平台。它能让你把HTML5应用打包成本地桌面应用或游戏安装到Windows、Linux或Mac系统中。Node-Webkit项目是由英特尔开源技术中心开发,发起人是王文睿。

为什么Node-WebKit是开发HTML5本地桌面应用的最佳选择

  1. Node-WebKit能把你的HTML5应用打包成本地桌面应用,在Windows、Linux或Mac平台上,你不需要其它依赖就可以独立运行你的HTML5应用。
  2. 它支持Node.js。你可以使用Node.js的所有模块来开发你喜欢的app或游戏。不仅你可以使用Node.js原生的模块,而且可以使用第三方的node.js模块。

如何使用Node-Webkit开发HTML5本地桌面应用

这非常简单,像传统的开发你的HTML5应用一样开发它们,完成之后用Node-Webkit打包它。打包的方法是

1.先下载Node-Webkit

2.然后创建一个包文件命名为package.json, 写入下面的代码:

{
 "name": "nw-demo",
 "main": "index.html"
}

这里的“name”是你应用的名称,“main”是你的应用的启动文件,也就是应用启动是第一加载的文件。

3.将你的HTML5应用文件和package.json一起打包成zip

4.重命名zip文件,将其后缀变成 .nw ,比如app.nw

5.现在你就可以用node-webkit runtime来运行你的app了在Linux上的运行命令是

./nw app.nw

在Windows平台上你可以直接把你的app.nw拖拽到 nw.exe 程序上就行了。

6.想让你的应用更容易传播和发布,可以将它和node-webkit封装到一起,也就是将你的HTML5应用 app.nw 和 nw.exe 合成一个可执行文件。在Linux上的做法是

cat /usr/bin/nw app.nw > app && chmod +x app

在Window上的做法是

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

你可以看看这个wiki文档,里面有更详细的介绍。希望这篇文章对你有所帮助。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
jquery关于页面焦点的定位(文本框获取焦点时改变样式 )
Sep 10 Javascript
关于Javascript模块化和命名空间管理的问题说明
Dec 06 Javascript
Extjs优化(二)Form表单提交通用实现
Apr 15 Javascript
js播放wav文件(源码)
Apr 22 Javascript
设置点击文本框或图片弹出日历控件的实现代码
May 12 Javascript
Vue.js第二天学习笔记(vue-router)
Dec 01 Javascript
canvas绘制多边形
Feb 24 Javascript
使用Vue-Router 2实现路由功能实例详解
Nov 14 Javascript
webpack的CSS加载器的使用
Sep 11 Javascript
微信小程序云开发获取文件夹下所有文件(推荐)
Nov 14 Javascript
vue使用openlayers实现移动点动画
Sep 24 Javascript
JavaScript ES 模块的使用
Nov 12 Javascript
AngularJS中$apply方法和$watch方法用法总结
Dec 13 #Javascript
vue.js学习之递归组件
Dec 13 #Javascript
AngularJS过滤器filter用法总结
Dec 13 #Javascript
ES6通过babel转码使用webpack使用import关键字
Dec 13 #Javascript
AngularJS服务service用法总结
Dec 13 #Javascript
Vue.js中用v-bind绑定class的注意事项
Dec 13 #Javascript
AngularJS中的Promise详细介绍及实例代码
Dec 13 #Javascript
You might like
ThinkPHP使用心得分享-分页类Page的用法
2014/05/15 PHP
php动态生成版权所有信息的方法
2015/03/24 PHP
php 生成签名及验证签名详解
2016/10/26 PHP
Javascript计算时间差的函数分享
2011/07/04 Javascript
jquery ajax中使用jsonp的限制解决方法
2013/11/22 Javascript
JavaScript+CSS控制打印格式示例介绍
2014/01/07 Javascript
javascript文件中引用依赖的js文件的方法
2014/03/17 Javascript
Node.js 异步编程之 Callback介绍(一)
2015/03/30 Javascript
jquery实现简单Tab切换菜单效果
2020/07/17 Javascript
[原创]jQuery常用的4种加载方式分析
2016/07/25 Javascript
Bootstrap和Java分页实例第一篇
2016/12/23 Javascript
Node调用Java的示例代码
2017/09/20 Javascript
vue.js语法及常用指令
2017/10/29 Javascript
微信小程序实现分享到朋友圈功能
2018/07/19 Javascript
[46:20]CHAOS vs Alliacne 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/16 DOTA
Python使用爬虫猜密码
2016/02/19 Python
Python+tkinter使用80行代码实现一个计算器实例
2018/01/16 Python
python执行精确的小数计算方法
2019/01/21 Python
Django实现学员管理系统
2019/02/26 Python
python使用 zip 同时迭代多个序列示例
2019/07/06 Python
Python queue队列原理与应用案例分析
2019/09/27 Python
Python如何使用队列方式实现多线程爬虫
2020/05/12 Python
python opencv把一张图片嵌入(叠加)到另一张图片上的实现代码
2020/06/11 Python
用Python实现童年贪吃蛇小游戏功能的实例代码
2020/12/07 Python
CSS中几个与换行有关的属性简明总结
2014/04/15 HTML / CSS
优瑞自动咖啡机官网:Jura
2018/09/29 全球购物
Collection和Collections的区别
2016/05/02 面试题
毕业自荐书
2013/12/09 职场文书
教师一岗双责责任书
2014/04/16 职场文书
公司授权委托书样本
2014/09/15 职场文书
关于调整工作时间的通知
2015/04/24 职场文书
2015年学校教研室主任工作总结
2015/07/20 职场文书
个人工作失误的保证书怎么写?
2019/06/21 职场文书
Java 数据结构七大排序使用分析
2022/04/02 Java/Android
美国运营商 T-Mobile 以 117.83Mb/s 的速度排第一位
2022/04/21 数码科技
鲲鹏 CentOS 7 安装Python3.7
2022/05/11 Servers