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 相关文章推荐
Javascript Select操作大集合
May 26 Javascript
javascript 获取元素样式必杀技
May 04 Javascript
js控制输入框获得和失去焦点时状态显示的方法
Jan 30 Javascript
整理Javascript事件响应学习笔记
Dec 02 Javascript
jquery ztree实现模糊搜索功能
Feb 25 Javascript
AngularJS使用ng-repeat指令实现下拉框
Aug 23 Javascript
react实现pure render时bind(this)隐患需注意!
Mar 09 Javascript
详解webpack异步加载业务模块
Jun 23 Javascript
vue使用element-ui的el-input监听不了回车事件的解决方法
Jan 12 Javascript
vue+webpack实现异步组件加载的方法
Feb 03 Javascript
JS实现省市县三级下拉联动
Apr 10 Javascript
基于原生JS封装的Modal对话框插件的示例代码
Sep 09 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
php 运行效率总结(提示程序速度)
2009/11/26 PHP
PHP改进计算字符串相似度的函数similar_text()、levenshtein()
2014/10/27 PHP
php中使用url传递数组的方法
2015/02/11 PHP
PHP实现搜索相似图片
2015/09/22 PHP
javascript 获取网页参数系统
2008/07/19 Javascript
根据json字符串生成Html的一种方式
2013/01/09 Javascript
ECMAScript5(ES5)中bind方法使用小结
2015/05/07 Javascript
SublimeText自带格式化代码功能之reindent
2015/12/27 Javascript
JQuery在循环中绑定事件的问题详解
2016/06/02 Javascript
jQuery插件cxSelect多级联动下拉菜单实例解析
2016/06/24 Javascript
Bootstrap轮播图的使用和理解4
2016/12/14 Javascript
深入理解Vuex 模块化(module)
2017/09/26 Javascript
vue+vuex+json-seiver实现数据展示+分页功能
2019/04/11 Javascript
layui之table checkbox初始化时选中对应选项的方法
2019/09/02 Javascript
[03:03]2014DOTA2国际邀请赛 EG战队专访
2014/07/12 DOTA
python解析发往本机的数据包示例 (解析数据包)
2014/01/16 Python
python解析文件示例
2014/01/23 Python
python向已存在的excel中新增表,不覆盖原数据的实例
2018/05/02 Python
Python爬取商家联系电话以及各种数据的方法
2018/11/10 Python
python格式化输出保留2位小数的实现方法
2019/07/02 Python
python3.7简单的爬虫实例详解
2019/07/08 Python
Python3的高阶函数map,reduce,filter的示例详解
2019/07/23 Python
python使用Geany编辑器配置方法
2020/02/21 Python
python怎么判断素数
2020/07/01 Python
Python面向对象多态实现原理及代码实例
2020/09/16 Python
欧舒丹英国官网:购买欧舒丹护手霜等明星产品
2017/01/17 全球购物
印度低票价航空公司:GoAir
2017/10/11 全球购物
SKECHERS官方旗舰店:美国舒适运动休闲品牌
2017/12/22 全球购物
adidas马来西亚官网:adidas MY
2020/09/12 全球购物
进口业务员岗位职责
2014/04/06 职场文书
学生操行评语大全
2014/04/24 职场文书
关于环保的演讲稿
2014/05/10 职场文书
优秀三好学生事迹材料
2014/08/31 职场文书
Vue鼠标滚轮滚动切换路由效果的实现方法
2021/08/04 Vue.js
Python常遇到的错误和异常
2021/11/02 Python
磁贴还没死, 微软Win11可修改注册表找回Win10开始菜单
2021/11/21 数码科技