详解Angular CLI + Electron 开发环境搭建
发布时间 - 2026-01-11 02:25:27 点击率:次本文介绍了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 提供的会将这部分代码编译掉,程序就会报错,那怎么办呢?有以下几个方法:
- 直接使用 Webpack 构建项目,Webpack 在配置文件中提供了 target 配置项,设置为 electron-renderer 就可以了。
- 使用 ng eject 弹出配置文件,然后在 webpack.config.js 中配置 "target": "electron-renderer" ,可以达到配置 webpack 的效果。
- 还有最后一个笨办法,那就是在每个使用 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中使用的解决办法
# 几个
# 配置文件
# 就可以
# 大佬
# 都是
# 就会
# 是在
# 我在
# 还没
# 放在
# 起来了
# 各有千秋
# 我把
# 这部
# 给大家
# 弹出
# 可以实现
# 种方法
# 按下
# 并不能
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
Laravel如何升级到最新版本?(升级指南和步骤)
网易LOFTER官网链接 老福特网页版登录地址
如何在 Pandas 中基于一列条件计算另一列的分组均值
Laravel Sail是什么_基于Docker的Laravel本地开发环境Sail入门
如何用虚拟主机快速搭建网站?详细步骤解析
Laravel如何使用Collections进行数据处理?(实用方法示例)
如何在IIS中新建站点并配置端口与物理路径?
弹幕视频网站制作教程下载,弹幕视频网站是什么意思?
Linux网络带宽限制_tc配置实践解析【教程】
Laravel如何实现登录错误次数限制_Laravel自带LoginThrottles限流配置【方法】
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
如何快速搭建虚拟主机网站?新手必看指南
学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?
如何快速搭建高效简练网站?
Laravel Session怎么存储_Laravel Session驱动配置详解
无锡营销型网站制作公司,无锡网选车牌流程?
Edge浏览器怎么启用睡眠标签页_节省电脑内存占用优化技巧
魔方云NAT建站如何实现端口转发?
如何在IIS管理器中快速创建并配置网站?
Laravel如何使用Passport实现OAuth2?(完整配置步骤)
百度浏览器如何管理插件 百度浏览器插件管理方法
Laravel如何自定义错误页面(404, 500)?(代码示例)
网站图片在线制作软件,怎么在图片上做链接?
Android GridView 滑动条设置一直显示状态(推荐)
如何撰写建站申请书?关键要点有哪些?
Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件
Laravel如何使用软删除(Soft Deletes)功能_Eloquent软删除与数据恢复方法
Laravel如何处理JSON字段_Eloquent原生JSON字段类型操作教程
标题:Vue + Vuex + JWT 身份认证的正确实践与常见误区解析
Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权
高端建站如何打造兼具美学与转化的品牌官网?
如何快速配置高效服务器建站软件?
Laravel如何实现API速率限制?(Rate Limiting教程)
Laravel怎么在Controller之外的地方验证数据
Laravel如何使用Livewire构建动态组件?(入门代码)
网站制作免费,什么网站能看正片电影?
千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】
Laravel如何操作JSON类型的数据库字段?(Eloquent示例)
Laravel如何使用Service Container和依赖注入?(代码示例)
如何用景安虚拟主机手机版绑定域名建站?
Windows10电脑怎么查看硬盘通电时间_Win10使用工具检测磁盘健康
Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】
如何快速启动建站代理加盟业务?
香港服务器建站指南:免备案优势与SEO优化技巧全解析
WEB开发之注册页面验证码倒计时代码的实现
Linux安全能力提升路径_长期防护思维说明【指导】
在线制作视频网站免费,都有哪些好的动漫网站?
打造顶配客厅影院,这份100寸电视推荐名单请查收
如何在HTML表单中获取用户输入并结合JavaScript动态控制复利计算循环
微信小程序 wx.uploadFile无法上传解决办法

