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 相关文章推荐
JS中字符问题(二进制/十进制/十六进制及ASCII码之间的转换)
Nov 03 Javascript
15个款优秀的 jQuery 图片特效插件推荐
Nov 21 Javascript
Package.js  现代化的JavaScript项目make工具
May 23 Javascript
兼容FF和IE的动态table示例自写
Oct 21 Javascript
jQuery中not()方法用法实例
Jan 06 Javascript
javascript+html5实现绘制圆环的方法
Jul 28 Javascript
javascript鼠标滑过显示二级菜单特效
Nov 18 Javascript
解决OneThink中无法异步提交kindeditor文本框中修改后的内容方法
May 05 Javascript
面包屑导航详解
Dec 07 Javascript
快速解决vue动态绑定多个class的官方实例语法无效的问题
Sep 05 Javascript
Vue实现导航栏菜单
Aug 19 Javascript
解决element-ui的下拉框有值却无法选中的情况
Nov 07 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
在smarty模板中使用PHP函数的方法
2011/04/23 PHP
php修改时间格式的代码
2011/05/29 PHP
小谈php正则提取图片地址
2014/03/27 PHP
thinkphp中的url跳转用法分析
2016/07/12 PHP
thinkphp实现附件上传功能
2017/05/26 PHP
PHP预定义超全局数组变量小结
2018/08/20 PHP
jQuery使用手册之 事件处理
2007/03/24 Javascript
javascript html 静态页面传参数
2009/04/10 Javascript
Javascript在IE或Firefox下获取鼠标位置的代码
2009/12/18 Javascript
javascript中删除指定数组中指定的元素的代码
2011/02/12 Javascript
15个jquery常用方法、小技巧分享
2015/01/13 Javascript
js+canvas简单绘制圆圈的方法
2016/01/28 Javascript
有关jquery与DOM节点操作方法和属性记录
2016/04/15 Javascript
实例浅析js的this
2016/12/11 Javascript
select获取下拉框的值 下拉框默认选中方法
2018/02/28 Javascript
JS获取浏览器地址栏的多个参数值的任意值实例代码
2018/07/24 Javascript
Python脚本实现自动发带图的微博
2016/04/27 Python
python中子类调用父类函数的方法示例
2017/08/18 Python
Python变量赋值的秘密分享
2018/04/03 Python
python求最大连续子数组的和
2018/07/07 Python
python字符串切割:str.split()与re.split()的对比分析
2019/07/16 Python
Python requests获取网页常用方法解析
2020/02/20 Python
Python实现Wordcloud生成词云图的示例
2020/03/30 Python
Python flask框架如何显示图像到web页面
2020/06/03 Python
浅析Python 条件控制语句
2020/07/15 Python
python爬虫利用selenium实现自动翻页爬取某鱼数据的思路详解
2020/12/22 Python
英国足球店:UK Soccer Shop
2017/11/19 全球购物
美国打印机墨水和碳粉购物网站:QuikShip Toner
2018/08/29 全球购物
建筑工程技术应届生求职信
2013/11/17 职场文书
学校办公室主任职责
2013/12/27 职场文书
机械设备与数控技术专业求职信
2014/08/10 职场文书
2014年政风行风工作总结
2014/11/22 职场文书
2015建军节87周年演讲稿
2015/03/19 职场文书
请客吃饭开场白
2015/06/01 职场文书
六一文艺汇演主持词
2015/06/30 职场文书
高中政治教师教学反思
2016/02/23 职场文书