本篇內(nèi)容介紹了“SAP中使用SAP UI5的獨(dú)特之處是什么”的有關(guān)知識,在實(shí)際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
從策劃到設(shè)計制作,每一步都追求做到細(xì)膩,制作可持續(xù)發(fā)展的企業(yè)網(wǎng)站。為客戶提供網(wǎng)站建設(shè)、做網(wǎng)站、網(wǎng)站策劃、網(wǎng)頁設(shè)計、域名注冊、虛擬空間、網(wǎng)絡(luò)營銷、VI設(shè)計、 網(wǎng)站改版、漏洞修補(bǔ)等服務(wù)。為客戶提供更好的一站式互聯(lián)網(wǎng)解決方案,以客戶的口碑塑造優(yōu)易品牌,攜手廣大客戶,共同發(fā)展進(jìn)步。下面就以Account這個工作中心視圖頁面為例來看。
首先,我們知道在UI Designer里面畫好了頁面后,會生成對應(yīng)的XML文件存儲在ABAP后臺。同時,我們在UI Designer里面也可以看到生成的XML文件:
我們可以看到上圖紅色區(qū)域標(biāo)注的標(biāo)簽EmbeddedComponents,里面的targetComponentID指向一個Object Work List(OWL)。這個OWL也就是我們在Account工作視圖上看到的OWL, 如下圖。
那么在運(yùn)行時這些XML文件是如何被渲染出來的呢?
運(yùn)行時有一個JavaScript對象來打開窗口,該對象的實(shí)現(xiàn)位于文件MWindowManager.js。我們在這里打斷點(diǎn)可以看出_open方法觸發(fā)了整個頁面的渲染。當(dāng)我們點(diǎn)擊Account工作中心視圖的時候,會把視圖所在路徑傳入此方法。
進(jìn)入后續(xù)的處理邏輯,這里會根據(jù)resource path(也就是之前提到的視圖所在地址)去向后臺發(fā)送一個請求,取回一個JSON model,然后執(zhí)行回調(diào)函數(shù)。
接下來我們?nèi)タ椿卣{(diào)里面做了什么。
觀察從后臺返回的HTTP響應(yīng),發(fā)現(xiàn)是一個JSON模型,包含了這個頁面具體的組件信息。這里就可以跟前面我們看到的XML對應(yīng)上了。接著程序會去取這些組件的render manager,并執(zhí)行render(渲染)操作。
我的同事,SAP成都研究院小李探花周帥,在他的文章淺談Fiori Design Guidelines里曾經(jīng)提到,C4C有三套UI,Silverlight,HTML5和RUI。其中HTML5和RUI都基于SAP UI5。那么什么時候去渲染HTML5的控件,什么時候又去渲染RUI的控件呢?實(shí)際上每一個UI控件都有其對應(yīng)的renderer,那具體是哪一個render來負(fù)責(zé)生成HTML5源代碼,就是由下面getRendererName里面的邏輯來取出對應(yīng)的renderer。
比如下圖是正在渲染RUI端的Tool Bar:
比如下圖所示正在渲染HTML5頁面上的紅框區(qū)域:
然而并不是所有的C4C UI都是通過UI Designer開發(fā)而成。C4C仍然存在部分UI5傳統(tǒng)的XML視圖。
以Visit工作中心為示例,選擇某個survey打開:
打開的Survey明細(xì)頁面卻是通過UI5 XML視圖實(shí)現(xiàn)的:
那么問題來了,UI Designer開發(fā)的視圖里包含的超鏈接,如何能夠指向一個UI5 XML視圖?
首先找到這個超鏈接點(diǎn)擊的OnClick處理函數(shù)OnSurveyPreview:
OnSurveyPreview的處理有三個分支,這不難理解。因?yàn)榍懊嬲f過C4C有三套UI,SilverLight,HTML5和RUI。盡管這三套UI共享同一個UI Designer的開發(fā)視圖,然而點(diǎn)擊超鏈接后的跳轉(zhuǎn)邏輯略微有差異,因此在OnClick處理函數(shù)OnSurveyPreview里分三個分支處理。下圖中間紅色區(qū)域的分支代碼在RUI里點(diǎn)擊超鏈接的跳轉(zhuǎn)實(shí)現(xiàn)。
點(diǎn)擊上圖中間的紅色分支,發(fā)現(xiàn)RUI的超鏈接點(diǎn)擊跳轉(zhuǎn)實(shí)現(xiàn)的函數(shù)為:OnOpenResponsiveSurvey
該函數(shù)最后會打開一個CustomControl:
這個CustomControl的路徑,即對應(yīng)JavaScript的實(shí)現(xiàn),維護(hù)在UI Designer里:
在運(yùn)行時,該Custom Control的JavaScript實(shí)現(xiàn)會使用JavaScript代碼創(chuàng)建XML視圖實(shí)例,如下圖第127行,XML視圖的構(gòu)造函數(shù)被調(diào)用,
這就是為什么點(diǎn)了超鏈接之后,從Chrome開發(fā)者工具里能看到main.view.xml文件的加載:
“SAP中使用SAP UI5的獨(dú)特之處是什么”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!