时间:2021-05-25
本文介绍了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-reloadelectron-reload 这个是 electron 的一个可以检测文件变化而实时刷新的包,在配置中配置这个每次文件更改后程序都会实时刷新。
Electron 是使用 index.js 作为入口文件的,可以去网上看相关教程,下面我把我的 index.js 文件贴出来供大家参考:
// index.jsconst { 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 } }); // 加载应用的 index.html win.loadURL(`file://${__dirname}/dist/index.html`); // 打开开发工具 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 文件夹下的 index.html 文件。同时我们最好将静态文件都放在 src/assets 文件夹下,然后配置在 dist/assets 文件夹下就好了。
测试
可以在项目文件夹中运行以下命令查看效果了:
$ ng build --watch true$ electron ./这样就可以将项目启动起来了,而且可以实时监测文件的变化刷新软件,很便捷。
一些问题
现在软件基本可以跑起来了,但是在项目中只能使用 Chrome API,Electron 和 Node.js 提供的 API 在项目中并不能使用,因为 @angular/cli 提供的会将这部分代码编译掉,程序就会报错,那怎么办呢?有以下几个方法:
这三种方法都可以实现在 @angular/cli 创建的项目中使用 Electron 或 Node.js API,但都是略麻烦,希望 项目自尽快放开 target 的配置吧。
小尾巴
下面是我最近正在用 Angular4 和 Electron 构建的项目,还没开发完成,希望给新手参考一下,也希望大佬多多指点!
最近尝试着构建了几个小项目,发现框架之类的主要是使用上的差别,重要的还是在大型项目中的数据架构的处理,目前我在使用的数据架构主要有 redux 和 rxjs ,各有千秋,将数据架构与框架结合起来才能实现清晰明了、简单易开发的项目,努力向这个方法加油。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前序:现在angular2已经除了集成的angular-cli,建议大家可以基于这个来快速开发ng2的项目,不用自己再搭建环境;相关内容请前往:https://
准备前提:已经搭建好angular-cli环境,还未搭建好的请参见https://ponent注解内容解释selector 指定该组件使用什么DOM元素例如代
搭建vue的开发环境:1、必须要安装nodejs2、搭建vue的开发环境,安装vue的脚手架工具官方命令行工具npminstall--globalvue-cli
本文介绍了React全家桶环境搭建过程详解,分享给大家,具体如下:环境搭建1.从零开始搭建webpack+react开发环境2.引入Typescript安装依赖
详解Angular-cli生成组件修改css成less或sass的实例使用cli命令生成组件:nggeneratecomponent组件名生成出来的组件文件有: