您好,登錄后才能下訂單哦!
本篇內容主要講解“Angular和SAP C4C的事件處理隊列分析”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Angular和SAP C4C的事件處理隊列分析”吧!
我們在Angular框架的代碼里能看到一個名為processQueue的函數:
這個函數是通過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發現由apply觸發的JavaScript執行序列里又出現了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 evalAsync would
// lead to a '$digest already in progress' error.
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屬性。
到此,相信大家對“Angular和SAP C4C的事件處理隊列分析”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。