詳解Angular CLI + Electron 開發(fā)環(huán)境搭建
本文介紹了Angular CLI + Electron 開發(fā)環(huán)境搭建,分享給大家
用 @angular/cli 配合 Electron 構(gòu)建桌面軟件開發(fā)環(huán)境,可以在 Electron 中使用 Angular 的各種特性,使開發(fā)桌面軟件像開發(fā)網(wǎng)站一樣簡單、快捷,而且可以模塊化,緊跟最新技術(shù)趨勢。
安裝 Angular CLI 和 Electron
首先使用 npm 安裝 Angular Cli:
$ npm i -g @angular/cli
然后安裝 Electron
$ npm i -g electron
創(chuàng)建項(xiàng)目
用 Angular CLI 創(chuàng)建一個(gè)新項(xiàng)目:
$ ng new PROJECT-NAME --style=scss $ cd PROJECT-NAME $ npm i
這里選擇使用 SCSS 作為 css 預(yù)處理器。
構(gòu)建 Electron 配置
安裝本地 Electron 依賴:
$ npm i -D electron electron-reload
electron-reload 這個(gè)是 electron 的一個(gè)可以檢測文件變化而實(shí)時(shí)刷新的包,在配置中配置這個(gè)每次文件更改后程序都會(huì)實(shí)時(shí)刷新。
Electron 是使用 index.js 作為入口文件的,可以去網(wǎng)上看相關(guān)教程,下面我把我的 index.js 文件貼出來供大家參考:
// index.js
const {
app, // 控制應(yīng)用生命周期的模塊。
BrowserWindow, // 創(chuàng)建原生瀏覽器窗口的模塊
} = require('electron');
require('electron-reload')(__dirname);
// 保持一個(gè)對于 window 對象的全局引用,不然,當(dāng) JavaScript 被 GC,window 會(huì)被自動(dòng)地關(guān)閉
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
}
});
// 加載應(yīng)用的 index.html
win.loadURL(`file://${__dirname}/dist/index.html`);
// 打開開發(fā)工具
win.webContents.openDevTools();
// 當(dāng) window 被關(guān)閉,這個(gè)事件會(huì)被發(fā)出
win.on('closed', () => win = null);
win.on('ready-to-show', () => {
win.show();
win.focus();
})
};
// 當(dāng) Electron 完成了初始化并且準(zhǔn)備創(chuàng)建瀏覽器窗口的時(shí)候這個(gè)方法就被調(diào)用
app.on('ready', createWindow);
// 當(dāng)所有窗口被關(guān)閉時(shí),退出程序
app.on('window-all-closed', () => {
// 在 OS X 上,通常用戶在明確地按下 Cmd + Q 之前應(yīng)用會(huì)保持活動(dòng)狀態(tài)
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();
});
因?yàn)槲覀兪褂?Angular CLI 編譯后的文件是輸出在 dist 文件夾的,所以我們要配置 loadURL 的地址為 dist 文件夾下的 index.html 文件。同時(shí)我們最好將靜態(tài)文件都放在 src/assets 文件夾下,然后配置在 dist/assets 文件夾下就好了。
測試
可以在項(xiàng)目文件夾中運(yùn)行以下命令查看效果了:
$ ng build --watch true $ electron ./
這樣就可以將項(xiàng)目啟動(dòng)起來了,而且可以實(shí)時(shí)監(jiān)測文件的變化刷新軟件,很便捷。
一些問題
現(xiàn)在軟件基本可以跑起來了,但是在項(xiàng)目中只能使用 Chrome API,Electron 和 Node.js 提供的 API 在項(xiàng)目中并不能使用,因?yàn)?@angular/cli 提供的會(huì)將這部分代碼編譯掉,程序就會(huì)報(bào)錯(cuò),那怎么辦呢?有以下幾個(gè)方法:
- 直接使用 Webpack 構(gòu)建項(xiàng)目,Webpack 在配置文件中提供了 target 配置項(xiàng),設(shè)置為 electron-renderer 就可以了。
- 使用 ng eject 彈出配置文件,然后在 webpack.config.js 中配置 "target": "electron-renderer" ,可以達(dá)到配置 webpack 的效果。
- 還有最后一個(gè)笨辦法,那就是在每個(gè)使用 Electron 或 Node.js API 的文件中的頂部都使用 TypeScript 的聲明來聲明 require ,強(qiáng)制不編譯 require ,方法如下;
declare global {
interface Window {
require: any;
}
}
const electron = window.require('electron');
這三種方法都可以實(shí)現(xiàn)在 @angular/cli 創(chuàng)建的項(xiàng)目中使用 Electron 或 Node.js API,但都是略麻煩,希望 項(xiàng)目自盡快放開 target 的配置吧。
小尾巴
下面是我最近正在用 Angular4 和 Electron 構(gòu)建的項(xiàng)目,還沒開發(fā)完成,希望給新手參考一下,也希望大佬多多指點(diǎn)!
最近嘗試著構(gòu)建了幾個(gè)小項(xiàng)目,發(fā)現(xiàn)框架之類的主要是使用上的差別,重要的還是在大型項(xiàng)目中的數(shù)據(jù)架構(gòu)的處理,目前我在使用的數(shù)據(jù)架構(gòu)主要有 redux 和 rxjs ,各有千秋,將數(shù)據(jù)架構(gòu)與框架結(jié)合起來才能實(shí)現(xiàn)清晰明了、簡單易開發(fā)的項(xiàng)目,努力向這個(gè)方法加油。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 使用electron制作滿屏心特效的示例代碼
- electron制作仿制qq聊天界面的示例代碼
- electron + vue項(xiàng)目實(shí)現(xiàn)打印小票功能及實(shí)現(xiàn)代碼
- electron中使用bootstrap的示例代碼
- Electron中實(shí)現(xiàn)大文件上傳和斷點(diǎn)續(xù)傳功能
- 從零開始用electron手?jǐn)]一個(gè)截屏工具的示例代碼
- 使用electron將vue-cli項(xiàng)目打包成exe的方法
- 解決npm安裝Electron緩慢網(wǎng)絡(luò)超時(shí)導(dǎo)致失敗的問題
- 詳解Webpack實(shí)戰(zhàn)之構(gòu)建 Electron 應(yīng)用
- 關(guān)于node-bindings無法在Electron中使用的解決辦法
相關(guān)文章
AngularJS實(shí)現(xiàn)的base64編碼與解碼功能示例
這篇文章主要介紹了AngularJS實(shí)現(xiàn)的base64編碼與解碼功能,結(jié)合實(shí)例形式分析了AngularJS字符串base64編碼與解碼操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2018-05-05
AngularJS 應(yīng)用身份認(rèn)證的技巧總結(jié)
這篇文章主要介紹了AngularJS 應(yīng)用身份認(rèn)證的技巧總結(jié),具有一定的參考價(jià)值,有需要的可以了解一下。2016-11-11
Angular項(xiàng)目過大時(shí)的合理拆分angular?split
這篇文章主要為大家介紹了Angular項(xiàng)目過大時(shí)的合理拆分angular?split示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07
使用JavaScript的AngularJS庫編寫hello world的方法
這篇文章主要介紹了使用JavaScript的AngularJS庫編寫hello world的方法,AngularJS是一款高人氣的JavaScript庫,需要的朋友可以參考下2015-06-06
在 Angular6 中使用 HTTP 請求服務(wù)端數(shù)據(jù)的步驟詳解
本文分步驟給大家介紹了在 Angular6 中使用 HTTP 請求服務(wù)端數(shù)據(jù)的方法,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2018-08-08
淺談angularjs依賴服務(wù)注入寫法的注意點(diǎn)
下面小編就為大家?guī)硪黄獪\談angularjs依賴服務(wù)注入寫法的注意點(diǎn)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04
AngularJS與后端php的數(shù)據(jù)交互方法
今天小編就為大家分享一篇AngularJS與后端php的數(shù)據(jù)交互方法,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08

