当前位置: 移动技术网 > IT编程>脚本编程>AngularJs > 详解Angular CLI + Electron 开发环境搭建

详解Angular CLI + Electron 开发环境搭建

2017年12月12日  | 移动技术网IT编程  | 我要评论

本文介绍了angular cli + electron 开发环境搭建,分享给大家

用 @angular/cli 配合 electron 构建桌面软件开发环境,可以在 electron 中使用 angular 的各种特性,使开发桌面软件像开发网站一样简单、快捷,而且可以模块化,紧跟最新技术趋势。

安装 angular cli 和 electron

首先使用 npm 安装 angular cli:

$ npm i -g @angular/cli

然后安装 electron

$ npm i -g electron

创建项目

用 angular cli 创建一个新项目:

$ ng new project-name --style=scss
$ cd project-name
$ npm i

这里选择使用 scss 作为 css 预处理器。

构建 electron 配置

安装本地 electron 依赖:

$ npm i -d electron electron-reload

electron-reload 这个是 electron 的一个可以检测文件变化而实时刷新的包,在配置中配置这个每次文件更改后程序都会实时刷新。

electron 是使用 index.js 作为入口文件的,可以去网上看相关教程,下面我把我的 index.js 文件贴出来供大家参考:

// index.js
const {
 app, // 控制应用生命周期的模块。
 browserwindow, // 创建原生浏览器窗口的模块
} = require('electron');
require('electron-reload')(__dirname);
// 保持一个对于 window 对象的全局引用,不然,当 javascript 被 gc,window 会被自动地关闭
let win;
const createwindow = ()=> {
 // create the browser window.
 win = new browserwindow({
 width: 1200,
 height: 800,
 frame: false,
 defaultfontsize: 16,
 minwidth: 1200,
 minheight: 800,
 icon: `file://${__dirname}/dist/assets/icon.png`,
 defaultmonospacefontsize: 16,
 defaultencoding: "utf-8",
 webpreferences: {
  plugins: true
 }
 });
 // 加载应用的 
 win.loadurl(`file://${__dirname}/dist/`);
 // 打开开发工具
 win.webcontents.opendevtools();
 // 当 window 被关闭,这个事件会被发出
 win.on('closed', () => win = null);
 win.on('ready-to-show', () => {
 win.show();
 win.focus();
 })
};
// 当 electron 完成了初始化并且准备创建浏览器窗口的时候这个方法就被调用
app.on('ready', createwindow);
// 当所有窗口被关闭时,退出程序
app.on('window-all-closed', () => {
 // 在 os x 上,通常用户在明确地按下 cmd + q 之前应用会保持活动状态
 process.platform !== 'darwin' && app.quit();
});
app.on('activate', () => {
 // on os x it's common to re-create a window in the app when the
 // dock icon is clicked and there are no other windows open.
 win === null && createwindow();
});

因为我们使用 angular cli 编译后的文件是输出在 dist 文件夹的,所以我们要配置 loadurl 的地址为 dist 文件夹下的 文件。同时我们最好将静态文件都放在 src/assets 文件夹下,然后配置在 dist/assets 文件夹下就好了。

测试

可以在项目文件夹中运行以下命令查看效果了:

$ ng build --watch true
$ electron ./

这样就可以将项目启动起来了,而且可以实时监测文件的变化刷新软件,很便捷。

一些问题

现在软件基本可以跑起来了,但是在项目中只能使用 chrome api,electron 和 node.js 提供的 api 在项目中并不能使用,因为 @angular/cli 提供的会将这部分代码编译掉,程序就会报错,那怎么办呢?有以下几个方法:

  1. 直接使用 webpack 构建项目,webpack 在配置文件中提供了 target 配置项,设置为 electron-renderer 就可以了。
  2. 使用 ng eject 弹出配置文件,然后在 webpack.config.js 中配置 "target": "electron-renderer" ,可以达到配置 webpack 的效果。
  3. 还有最后一个笨办法,那就是在每个使用 electron 或 node.js api 的文件中的顶部都使用 typescript 的声明来声明 require ,强制不编译 require ,方法如下;
declare global {
 interface window {
 require: any;
 }
}

const electron = window.require('electron');

这三种方法都可以实现在 @angular/cli 创建的项目中使用 electron 或 node.js api,但都是略麻烦,希望 项目自尽快放开 target 的配置吧。

小尾巴

下面是我最近正在用 angular4 和 electron 构建的项目,还没开发完成,希望给新手参考一下,也希望大佬多多指点!

最近尝试着构建了几个小项目,发现框架之类的主要是使用上的差别,重要的还是在大型项目中的数据架构的处理,目前我在使用的数据架构主要有 redux 和 rxjs ,各有千秋,将数据架构与框架结合起来才能实现清晰明了、简单易开发的项目,努力向这个方法加油。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网