91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

小談angular ng deploy的實現

發布時間:2020-10-15 17:22:07 來源:腳本之家 閱讀:154 作者:cipchk 欄目:web開發

Angular CLI 在 8.3.0 發布過一個新命令 ng deploy,可以將 Angular 應用部署到遠程服務器或云存儲上面,例如:Firebase hosting、Azure、GitHub pages 等等,這也是算是 Angular CLI 最后一個將 Angular 應用從開發到部署打通全能選手工具了。

快速入門

這里我以ng-deploy-oss 為示例,演示如何將 Angular 應用部署到七牛云。

1、創建一個新項目

ng new hello-world --defaults

2、添加 ng-deploy-oss

ng add ng-deploy-oss

命令行會讓你輸入幾個參數:

? 請選擇云類型? 七牛云
? 請輸入 AccessKey: test
? 請輸入 SecretKey: test
? 所在機房支持: qiniu.zone.Zone_z0 - 華東
? 請輸入 Bucket: ng-test
? 請輸入路徑前綴,如果不指定表示放在根目錄下: 
? 請輸入構建生產環境的 NPM 命令行(例如:npm run build),若為空表示自動根據 angular.json 構建生成環境 
UPDATE angular.json (3925 bytes)
UPDATE package.json (1511 bytes)

3、部署

ng deploy

最后直接打開瀏覽器,就能直接訪問 ng build --prod 后的效果。

原理

事實上,ng deploy 如同其他 Angular schematics 指令 ng add、ng g 等類同,我曾經在 淺談 Angular Cli Schematics 針對 Schematics 做過介紹。要自定義一個 ng deploy 只需要完成兩個部分:

  • 編寫 ng-add 來修改 angular.json 來告知使用哪個 Angular Libary 來部署;
  • 編寫上傳動作 createBuilder。

ng-add

給 angular.json 增加 deploy 節點:

{
  "serve": {},
+  "deploy": {
+    "builder": "ng-deploy-oss:deploy",
+    "options": {}
+  }
}

以及 package.json 的 devDependencies 增加依賴包:

+ "ng-deploy-oss": "~1.0.0",

有興趣可以參考 ng-deploy-oss 的 ng-add 的完整寫法。

createBuilder

它是一個固定的方法:

export default createBuilder<any>(async (schema: {}, context: BuilderContext): Promise<BuilderOutput> => {
  return { success: true };
});

將所有上傳相關的動作寫至該方法內;它返回的是一個 Promise<BuilderOutput> ,要告知 ng deploy 結束務必返回:return { success: true };。

如何部署至不同目標上

目前 ng deploy 只支持單個目標部署,有時多個遠程部署也是剛需,比如像當你在做一個開源時總需要照顧國內、國外時,總是希望一份 gh-pages 和 七牛云(免費額度),我們只需要修改 angular.json

{
  "serve": {},
+  "deploy-qiniu": {
+    "builder": "ng-deploy-oss:deploy",
+    "options": {}
+  },
+  "deploy-gh-pages": {
+    "builder": "angular-cli-ghpages:deploy",
+    "options": {}
+  }
}

注意:angular-cli-ghpages:deploy 引用的是 angular-cli-ghpages 依賴包。

然后使用 ng run 來調用這兩種不同目標:

ng run <project name>:deploy-qiniu
ng run <project name>:deploy-gh-pages

結論

Angular 在國內有些小窘境,ng deploy 發布這么久,一直都沒見到對國內一些云存儲進行適配;事實上,直接利用 ng deploy 來部署應用至遠程服務器上,可能在越來越多 Docker 應用后變得沒那么重要,但對于常寫開源的人來說,能夠快速將 Angular 應用部署至國內常見的幾個云存儲上還是挺有意義的。

到此這篇關于小談angular ng deploy的實現的文章就介紹到這了,更多相關angular ng deploy內容請搜索億速云以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持億速云!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

永平县| 巴楚县| 闽清县| 铜鼓县| 马鞍山市| 乌苏市| 隆昌县| 嘉荫县| 新和县| 寿光市| 玉环县| 比如县| 承德市| 名山县| 如皋市| 文登市| 获嘉县| 黄石市| 麻城市| 碌曲县| 宝坻区| 青铜峡市| 法库县| 包头市| 大化| 图木舒克市| 天柱县| 石棉县| 南通市| 巨鹿县| 墨脱县| 兴义市| 虹口区| 张掖市| 南昌县| 西畴县| 仙居县| 娄底市| 乌苏市| 合肥市| 宜都市|