从 1 到完美,用 js 和 electron 写一个桌面应用

从 1 到完美,用 js 和 electron 写一个桌面应用

目前用 js 和前端技术写桌面软件的方案主要有两种:electronnw.js。这二者在底层实现上有所不一样,简单的说,electron 是 node + chromium,nw.js 是 node + webkit。从使用上来讲,electron 的使用更为普遍,社区也更活跃,有一大批成熟的商用软件,像 vscode, atom等。因此,如今通常推荐使用 electron 来写桌面软件。前端

1. 选择合适的组件库和工具库

electron 社区多年的积累,已经有不少成熟的第三方组建库和工具库帮助你轻松的构建桌面应用,提升开发效率,避免重复造轮子。vue

组件库是用来帮助你书写程序的逻辑或者UI:node

工具库是用来帮助你构建程序:react

  • 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.linux

2. 选择合适的模板

社区有不少现成的模板,里面封装好了各类工具,打包成应用,建立安装文件等一系列功能,使用者只须要关注怎么编写应用,而不须要关心工具及各个命令的实现及原理。webpack

更多能够参考 https://github.com/search?o=desc&q=electron+boilerplate&s=stars&type=Repositories.git

若是你须要扩展功能,能够更改相关的配置文件。github

3. 开发应用与运行命令

electron-react-boilerplate 为例。web

web部分是以 react + redux + react-router + redux-thunk + react-redux,构建工具部分是以 webpack + babel + eslint + stylelint + prettier + flow + enzyme npm

另外,它封装了开发工具主要为如下几个命令:

3.1 dev 开发调试命令

npm run dev

这个命令将会运行一个 electron 应用实例,而后在本地开启一个本地 server 服务,当你编写渲染进程代码,本地 server 服务会自动刷新页面,而不须要关闭应用从新运行命令。

3.2 start 以发布模式启动应用

npm run start

与开发调试命令不一样的是,它不会开起本地 server 服务,也不会监听文件变更,而是会像发布的应用同样运行。这个通常在发布以前运行,查看应用的运行状况。

3.3 package 打包应用为安装文件

# 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

4. 应用实例

image-viewer 即是使用 electron-react-boilerplate 模板开发的一个图片浏览器应用。

5. 后续

更多博客,查看 https://github.com/senntyou/blogs

做者:深予之 (@senntyou)

版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证

相关文章
相关标签/搜索