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网页回到顶部效果(图标渐隐,自写)
Jun 16 Javascript
全面解析Bootstrap弹窗的实现方法
Dec 01 Javascript
JavaScript实现获取某个元素相邻兄弟节点的prev与next方法
Jan 25 Javascript
学习AngularJs:Directive指令用法(完整版)
Apr 26 Javascript
Vue实现双向绑定的方法
Dec 22 Javascript
基于JavaScript实现带缩略图的轮播效果
Jan 12 Javascript
ES6正则的扩展实例详解
Apr 25 Javascript
JS中数据结构之栈
Jan 01 Javascript
Vue-cli3项目引入Typescript的实现方法
Oct 18 Javascript
vue实现购物车加减
May 30 Javascript
vue elementUI表格控制对应列
Apr 13 Vue.js
JS实现九宫格拼图游戏
Jun 28 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/12/18 PHP
tp5框架内使用tp3.2分页的方法分析
2019/05/05 PHP
Js数组的操作push,pop,shift,unshift等方法详细介绍
2012/12/28 Javascript
自己写的Javascript计算时间差函数
2013/10/28 Javascript
js获取下拉列表框中的value和text的值示例代码
2014/01/11 Javascript
jquery中get和post的简单实例
2014/02/04 Javascript
javascript实现状态栏文字首尾相接循环滚动的方法
2015/07/22 Javascript
jQuery实现文件上传进度条特效
2015/08/12 Javascript
js实现iPhone界面风格的单选框和复选框按钮实例
2015/08/18 Javascript
Bootstrap基本样式学习笔记之按钮(4)
2016/12/07 Javascript
微信小程序实现图片轮播及文件上传
2017/04/07 Javascript
Vue入门之数据绑定(小结)
2018/01/08 Javascript
在vue中安装使用vux的教程详解
2018/09/16 Javascript
浅析Vue.js中v-bind v-model的使用和区别
2018/12/04 Javascript
关于vue状态过渡transition不起作用的原因解决
2019/04/09 Javascript
基于axios 的responseType类型的设置方法
2019/10/29 Javascript
vue-form表单验证是否为空值的实例详解
2019/10/29 Javascript
Vue实现按钮级权限方案
2019/11/21 Javascript
JS关闭子窗口并且刷新上一个窗口的实现示例
2020/03/10 Javascript
JavaScript进阶(四)原型与原型链用法实例分析
2020/05/09 Javascript
python赋值操作方法分享
2013/03/23 Python
Python使用Matplotlib模块时坐标轴标题中文及各种特殊符号显示方法
2018/05/04 Python
PyQt5的安装配置过程,将ui文件转为py文件后显示窗口的实例
2019/06/19 Python
python下载库的步骤方法
2019/10/12 Python
开启Django博客的RSS功能的实现方法
2020/02/17 Python
python如何进行矩阵运算
2020/06/05 Python
JDK安装目录下有哪些内容
2014/08/25 面试题
护理实习自我鉴定
2013/12/14 职场文书
大学运动会入场词
2014/02/22 职场文书
《棉鞋里的阳光》教学反思
2014/04/24 职场文书
毕业论文答辩开场白和结束语
2015/05/27 职场文书
社区挂职锻炼个人工作总结
2015/10/23 职场文书
2016教师暑期培训学习心得体会
2016/01/09 职场文书
党员反邪教心得体会
2016/01/15 职场文书
导游词之青城山景区
2019/09/27 职场文书
导游词之京东大峡谷旅游区
2019/10/29 职场文书