SAP Spartacus NgExpressEngineDecorator 的工作原理
首先看這個 class 的 get 定義:
接收兩個輸入參數,類型為:
- NgExpressEngine
- SsrOptimizationOptions
返回一個包裝后的 NgExpressEngine
NgExpressEngine 是 Spartacus 自己創建的類型,本質是一個函數,輸入參數為 NgSetupOptions,返回類型為 NgExpressEngineInstance.
后者又是一個函數,作為 ExpressEngine 的執行實例,接收 filePath,option 和 callback 作為參數。
一一對應:
返回一個新的函數,接收 E 即標準的 NgExpressEngine 的輸入參數作為輸入參數,同時將原來的兩個輸入參數 NgExpressEngine 和 Spartacus optimization 值存儲起來:
稍后,在 server.ts 里,我們調用這個被包裝之后的 ngExpressEngine,此時,輸入參數為一個對象,字段為 bootstrap,這個對象就是圖 E:NgSetupOptions
此時,執行函數體:
Object.assign() 方法用于將所有可枚舉屬性的值從一個或多個源對象分配到目標對象。它將返回目標對象。
調用 get 方法時傳入的值,通過閉包存儲在此:
三個點,就是將若干對象的不同名字段進行合并,最終結果:
其中閉包里的第一個輸入參數,即是標準的 ngExpressEngine:
這里就是 Angular 標準的實現了,我們不操心:
注意返回的類型:
創建 OptimizationEngine 實例:
最后,返回一個新的函數 renderResponse,且該函數執行時,執行上下文為 OptimizedSsrEngine 本身:
從現在開始,this.engines 指向 Spartacus 自己的 renderResponse 函數了:
更多Jerry的原創文章,盡在:“汪子熙”:
總結
以上是生活随笔為你收集整理的SAP Spartacus NgExpressEngineDecorator 的工作原理的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 新能源汽车4月狂卖60万辆 今年纯燃油新
- 下一篇: SAP 电商云 Spartacus UI