国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

詳解Angular CLI + Electron 開發(fā)環(huán)境搭建

2019-11-19 16:02:14
字體:
供稿:網(wǎng)友

本文介紹了Angular CLI + Electron 開發(fā)環(huán)境搭建,分享給大家

用 @angular/cli 配合 Electron 構(gòu)建桌面軟件開發(fā)環(huán)境,可以在 Electron 中使用 Angular 的各種特性,使開發(fā)桌面軟件像開發(fā)網(wǎng)站一樣簡(jiǎn)單、快捷,而且可以模塊化,緊跟最新技術(shù)趨勢(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è)可以檢測(cè)文件變化而實(shí)時(shí)刷新的包,在配置中配置這個(gè)每次文件更改后程序都會(huì)實(shí)時(shí)刷新。

Electron 是使用 index.js 作為入口文件的,可以去網(wǎng)上看相關(guān)教程,下面我把我的 index.js 文件貼出來供大家參考:

// index.jsconst { app, // 控制應(yīng)用生命周期的模塊。 BrowserWindow, // 創(chuàng)建原生瀏覽器窗口的模塊} = require('electron');require('electron-reload')(__dirname);// 保持一個(gè)對(duì)于 window 對(duì)象的全局引用,不然,當(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 文件夾下就好了。

測(cè)試

可以在項(xiàng)目文件夾中運(yùn)行以下命令查看效果了:

$ ng build --watch true$ electron ./

這樣就可以將項(xiàng)目啟動(dòng)起來了,而且可以實(shí)時(shí)監(jiān)測(cè)文件的變化刷新軟件,很便捷。

一些問題

現(xiàn)在軟件基本可以跑起來了,但是在項(xiàng)目中只能使用 Chrome API,Electron 和 Node.js 提供的 API 在項(xiàng)目中并不能使用,因?yàn)?@angular/cli 提供的會(huì)將這部分代碼編譯掉,程序就會(huì)報(bào)錯(cuò),那怎么辦呢?有以下幾個(gè)方法:

  1. 直接使用 Webpack 構(gòu)建項(xiàng)目,Webpack 在配置文件中提供了 target 配置項(xiàng),設(shè)置為 electron-renderer 就可以了。
  2. 使用 ng eject 彈出配置文件,然后在 webpack.config.js 中配置 "target": "electron-renderer" ,可以達(dá)到配置 webpack 的效果。
  3. 還有最后一個(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)清晰明了、簡(jiǎn)單易開發(fā)的項(xiàng)目,努力向這個(gè)方法加油。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 大渡口区| 中江县| 平和县| 宿松县| 建德市| 迁安市| 江川县| 扎鲁特旗| 北流市| 当阳市| 许昌县| 铜梁县| 建宁县| 加查县| 苍梧县| 镇原县| 中江县| 漳州市| 温州市| 静海县| 鄱阳县| 玉树县| 金乡县| 永德县| 航空| 海伦市| 汉寿县| 汨罗市| 页游| 米林县| 峨山| 陇南市| 陕西省| 桐城市| 客服| 兰西县| 北票市| 三门县| 万荣县| 松原市| 万荣县|