全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

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

本文介绍了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
 }
 });
 // 加载应用的 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 提供的会将这部分代码编译掉,程序就会报错,那怎么办呢?有以下几个方法:

  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 ,各有千秋,将数据架构与框架结合起来才能实现清晰明了、简单易开发的项目,努力向这个方法加油。

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


# Angular  # CLI  # Electron  # 环境搭建  # 使用electron制作满屏心特效的示例代码  # electron制作仿制qq聊天界面的示例代码  # electron + vue项目实现打印小票功能及实现代码  # electron中使用bootstrap的示例代码  # Electron中实现大文件上传和断点续传功能  # 从零开始用electron手撸一个截屏工具的示例代码  # 使用electron将vue-cli项目打包成exe的方法  # 解决npm安装Electron缓慢网络超时导致失败的问题  # 详解Webpack实战之构建 Electron 应用  # 关于node-bindings无法在Electron中使用的解决办法  # 几个  # 配置文件  # 就可以  # 大佬  # 都是  # 就会  # 是在  # 我在  # 还没  # 放在  # 起来了  # 各有千秋  # 我把  # 这部  # 给大家  # 弹出  # 可以实现  # 种方法  # 按下  # 并不能 


相关文章: 宝塔新建站点报错如何解决?  移民网站制作流程,怎么看加拿大移民官网?  如何在阿里云完成域名注册与建站?  智能起名网站制作软件有哪些,制作logo的软件?  个人网站制作流程图片大全,个人网站如何注销?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  武汉网站制作费用多少,在武汉武昌,建面100平方左右的房子,想装暖气片,费用大概是多少啊?  高端企业智能建站程序:SEO优化与响应式模板定制开发  西安制作网站公司有哪些,西安货运司机用的最多的app或者网站是什么?  c++23 std::expected怎么用 c++优雅处理函数错误返回【详解】  海南网站制作公司有哪些,海口网是哪家的?  制作表格网站有哪些,线上表格怎么弄?  网站制作报价单模板图片,小松挖机官方网站报价?    简单实现Android验证码  电视网站制作tvbox接口,云海电视怎样自定义添加电视源?  如何在Golang中处理模块冲突_解决依赖版本不兼容问题  建站之星安装后界面空白如何解决?  建站之星代理费用多少?最新价格详情介绍  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  公司网站制作价格怎么算,公司办个官网需要多少钱?  制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?  建站主机是否等同于虚拟主机?  建站之星代理如何优化在线客服效率?  高防服务器如何保障网站安全无虞?  建站主机核心功能解析:服务器选择与网站搭建流程指南  如何在建站主机中优化服务器配置?  专业网站制作企业网站,如何制作一个企业网站,建设网站的基本步骤有哪些?  如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?  如何规划企业建站流程的关键步骤?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?  如何选择可靠的免备案建站服务器?  定制建站策划方案_专业建站与网站建设方案一站式指南  音响网站制作视频教程,隆霸音响官方网站?  C++如何将C风格字符串(char*)转换为std::string?(代码示例)  如何快速搭建自助建站会员专属系统?  制作网站软件推荐手机版,如何制作属于自己的手机网站app应用?  贸易公司网站制作流程,出口贸易网站设计怎么做?  文字头像制作网站推荐软件,醒图能自动配文字吗?  高端云建站费用究竟需要多少预算?  Android使用GridView实现日历的简单功能  北京网站制作的公司有哪些,北京白云观官方网站?  已有域名建站全流程解析:网站搭建步骤与建站工具选择  如何在Golang中使用replace替换模块_指定本地或远程路径  建站主机选哪种环境更利于SEO优化?  如何用IIS7快速搭建并优化网站站点?  视频网站app制作软件,有什么好的视频聊天网站或者软件?  济南企业网站制作公司,济南社保单位网上缴费步骤?  网站制作网站,深圳做网站哪家比较好?  如何选择CMS系统实现快速建站与SEO优化? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。