目前用 js 和前端技术写桌面软件的方案主要有两种:electron 和 nw.js。这二者在底层实现上有所不一样,简单的说,electron 是 node + chromium,nw.js 是 node + webkit。从使用上来讲,electron 的使用更为普遍,社区也更活跃,有一大批成熟的商用软件,像 vscode, atom等。因此,如今通常推荐使用 electron 来写桌面软件。前端
electron 社区多年的积累,已经有不少成熟的第三方组建库和工具库帮助你轻松的构建桌面应用,提升开发效率,避免重复造轮子。vue
组件库是用来帮助你书写程序的逻辑或者UI:node
工具库是用来帮助你构建程序:react
更多能够参考 electron community.linux
社区有不少现成的模板,里面封装好了各类工具,打包成应用,建立安装文件等一系列功能,使用者只须要关注怎么编写应用,而不须要关心工具及各个命令的实现及原理。webpack
更多能够参考 https://github.com/search?o=desc&q=electron+boilerplate&s=stars&type=Repositories.git
若是你须要扩展功能,能够更改相关的配置文件。github
以 electron-react-boilerplate 为例。web
web部分是以 react + redux + react-router + redux-thunk + react-redux,构建工具部分是以 webpack + babel + eslint + stylelint + prettier + flow + enzyme npm
另外,它封装了开发工具主要为如下几个命令:
npm run dev
这个命令将会运行一个 electron 应用实例,而后在本地开启一个本地 server 服务,当你编写渲染进程代码,本地 server 服务会自动刷新页面,而不须要关闭应用从新运行命令。
npm run start
与开发调试命令不一样的是,它不会开起本地 server 服务,也不会监听文件变更,而是会像发布的应用同样运行。这个通常在发布以前运行,查看应用的运行状况。
# create installer for linux&win&mac. npm run package-all # create installer only for linux. npm run package-linux # create installer only for win. npm run package-win # create installer only for mac. npm run package-mac
image-viewer 即是使用 electron-react-boilerplate 模板开发的一个图片浏览器应用。
更多博客,查看 https://github.com/senntyou/blogs
版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证)