目前用 js 和前端技术写桌面软件的方案主要有两种:electron 和 nw.js。这两者在底层实现上有所不同,简单的说,electron 是 node + chromium,nw.js 是 node + webkit。从使用上来说,electron 的使用更为广泛,社区也更活跃,有一大批成熟的商用软件,像 vscode, atom等。所以,现在一般推荐使用 electron 来写桌面软件。
electron 社区多年的积累,已经有很多成熟的第三方组建库和工具库帮助你轻松的构建桌面应用,提高开发效率,避免重复造轮子。
组件库是用来帮助你书写程序的逻辑或者 UI:
- electron-store: 保存应用数据,比如数据缓存,应用配置等
- electron-context-menu: 创建右键菜单功能
- menubar: 创建状态栏视图
- photon: 一套快捷的组件库
- electron-log: 日志记录
工具库是用来帮助你构建程序:
- electron-builder: 创建应用的安装文件(win: exe, linux: deb, mac: dmg 等)
- devtron: 官方的 chromium DevTools 插件
- electron-packager: 把应用打包成一个可运行文件(win: exe, linux: deb, mac: dmg 等,非安装文件)
- spectron: electron 应用的测试工具
- electron-devtools-installer: 确保 electron 开发相关的 chromium DevTools 插件的安装
更多可以参考 electron community.
社区有很多现成的模板,里面封装好了各种工具,打包成应用,创建安装文件等一系列功能,使用者只需要关注怎么编写应用,而不需要关心工具及各个命令的实现及原理。
- electron-react-boilerplate: electron + react + redux
- electron-vue: electron + vue
- electron-boilerplate: electron
更多可以参考 https://github.com/search?o=desc&q=electron+boilerplate&s=stars&type=Repositories.
如果你需要扩展功能,可以更改相关的配置文件。
以 electron-react-boilerplate 为例。
web 部分是以 react + redux + react-router + redux-thunk + react-redux,构建工具部分是以 webpack + babel + eslint + stylelint + prettier + flow + enzyme
另外,它封装了开发工具主要为以下几个命令:
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/deepraining/blogs
版权声明:自由转载-非商用-非衍生-保持署名(创意共享 3.0 许可证)