日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

Angular和SAP C4C的事件处理队列

發布時間:2025/5/22 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Angular和SAP C4C的事件处理队列 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Angular

我們在Angular框架的代碼里能看到一個名為processQueue的函數:

這個函數是通過$scope.$apply啟動的:

核心代碼位于一個for循環里,循環體是一個存儲異步處理任務的隊列asyncQueuePosition:

for (var asyncQueuePosition = 0; asyncQueuePosition < asyncQueue.length; asyncQueuePosition++) {try {asyncTask = asyncQueue[asyncQueuePosition];fn = asyncTask.fn;fn(asyncTask.scope, asyncTask.locals);} catch (e) {$exceptionHandler(e);}lastDirtyWatch = null;}

隊列里每個元素長這樣的:一個處理函數fn,一個局部變量locals和scope對象:

這個注釋也非常有用:一旦Angular發現由$scope.$apply觸發的JavaScript執行序列里又出現了$scope.$apply的嵌套調用,會拋出錯誤消息:$digest already in progress

// It's safe for asyncQueuePosition to be a local variable here because this loop can't

// be reentered recursively. Calling $digest from a function passed to $evalAsync would

// lead to a '$digest already in progress' error.

C4C 事件隊列

C4C的事件處理器,EventProcessor.js有一個事件隊列:

該隊列的實現位于sap/client/evt/的OperationQueue.js中:

隨便在C4C UI做一個點擊,能觸發EventProcessor的_processQueue,C4C事件隊列的處理和Angular思路一樣,只不過是一個while循環替代了Angular的for循環:

C4C事件隊列里每個元素屬性如下,可以同Angular事件元素做對比:

fFunc就相當于Angular時間元素的fn屬性,environment相當于Angular事件元素的scope屬性。

要獲取更多Jerry的原創文章,請關注公眾號"汪子熙":

總結

以上是生活随笔為你收集整理的Angular和SAP C4C的事件处理队列的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。