欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

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

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

創(chuàng)新互聯(lián)建站主要從事成都網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)漢川,10年網(wǎng)站建設(shè)經(jīng)驗(yàn),價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):028-86922220

用 @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)建一個新項(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 這個是 electron 的一個可以檢測文件變化而實(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);
// 保持一個對于 window 對象的全局引用,不然,當(dāng) JavaScript 被 GC,window 會被自動地關(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)閉,這個事件會被發(fā)出
 win.on('closed', () => win = null);
 win.on('ready-to-show', () => {
 win.show();
 win.focus();
 })
};
// 當(dāng) Electron 完成了初始化并且準(zhǔn)備創(chuàng)建瀏覽器窗口的時候這個方法就被調(diào)用
app.on('ready', createWindow);
// 當(dāng)所有窗口被關(guān)閉時,退出程序
app.on('window-all-closed', () => {
 // 在 OS X 上,通常用戶在明確地按下 Cmd + Q 之前應(yī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 文件。同時我們最好將靜態(tài)文件都放在 src/assets 文件夾下,然后配置在 dist/assets 文件夾下就好了。

測試

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

$ ng build --watch true
$ electron ./

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

一些問題

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

  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. 還有最后一個笨辦法,那就是在每個使用 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)建了幾個小項(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)目,努力向這個方法加油。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

新聞名稱:詳解AngularCLI+Electron開發(fā)環(huán)境搭建
網(wǎng)站鏈接:http://aaarwkj.com/article38/gpipsp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供企業(yè)建站、域名注冊服務(wù)器托管、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站設(shè)計公司、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
黄色大片黄色大片黄色大片| 国产亚洲精品热视频在线观看| 尤物视频在线观看羞羞| 成年人性生活网站视频| 欧美日韩精品不卡在线播放| 久久激情日本人妻av免费| 精品亚洲在线一区二区| 全部网站免费在线观看等| 一区二区先锋深夜中文字幕| 国产av一区二区三区日韩接吻| 国产精品人一区二区三区| 视频二区国产欧美日韩| 欧美日韩精品一区二区在线播放| 日本黄色录像黄色录像| 日韩av一区二区国产| 91高清视频在线免费观看| 麻豆精品国产粉嫩av| 在线国产视频一区二区三区| 日本一区中文字幕欧美| 五月开心婷婷中文字幕| 国产精品色网在线播放| 亚洲欧美日韩性生活视频| 亚洲第一精品国产日韩| 午夜视频在线观看区一| 男男啪啪猛进猛出无遮挡| 避暑地堕落人妻中文字幕| 日韩深夜成人在线视频| 国产又猛又黄又爽无遮挡| 亚洲精品天堂av免费看| 日本成人午夜福利在线观看| 国产大片在线观看一区二区| 香港精品国产三级国产av| 国内精品免费视频不卡| 免费的黄色片带中文字幕| 国产激情久久久久久影院| 日韩亚洲在线中文字幕| 日韩在线啊啊啊的视频| 日本大胆高清人体艺术| 日本精品1区国产精品| 打开网址国语一级黄色片| 亚洲成人午夜免费在线观看|