天天看點

SAP UI5 初學者教程之十 - 什麼是 SAP UI5 應用的描述符 Descriptor 試讀版

教程目錄

SAP UI5 本地開發環境的搭建

SAP UI5 初學者教程之一:Hello World

SAP UI5 初學者教程之二:SAP UI5 的引導過程 Bootstrap

SAP UI5 初學者教程之三:開始接觸第一個 SAP UI5 控件

SAP UI5 初學者教程之四:XML 視圖初探

SAP UI5 初學者教程之五:視圖控制器初探

SAP UI5 初學者教程之六 - 了解 SAP UI5 的子產品(Module)概念

SAP UI5 初學者教程之七 - JSON 模型初探

SAP UI5 初學者教程之八 - 多語言的支援

SAP UI5 初學者教程之九 - 建立第一個 Component

SAP UI5 初學者教程之十 - 什麼是 SAP UI5 應用的描述符 Descriptor

說明

Jerry 從 2014 年加入 SAP成都研究院 CRM Fiori 開發團隊之後開始接觸 SAP UI5,曾經在 SAP 社群和“汪子熙”微信公衆号上發表過多篇關于 SAP UI5 工作原理和源碼解析的文章。

在 Jerry 這篇文章 對 SAP UI5 一無所知的新手,從哪些材料開始學習比較好? 曾經提到,Jerry 也是從 SAP UI5 菜鳥一路走過來,深知隻有 ABAP 開發背景的開發者,向 SAP UI5 開發領域轉型的不易,是以我在業餘時間設計了這份适合 SAP UI5 初學者的學習教程,把開發一個完整的 SAP UI5 應用的流程,拆分成若幹個步驟,力求每個步驟裡,把涉及到的知識點都涵蓋到。這些知識點可能不像我的 UI5 源碼分析系列文章那麼深入,但力求淺顯易懂,便于 SAP UI5 初學者了解。

本教程每一個步驟的源代碼,都存放在我的 Github 上,分别用檔案夾 01,02,03 等等來辨別。

SAP UI5 初學者教程之十 - 什麼是 SAP UI5 應用的描述符 Descriptor 試讀版

每一個步驟均是前一步驟的基礎上,添加了若幹新特性。建議零基礎或者對 SAP UI5 知之甚少的初學者,按照順序從第一個步驟開始循序漸進地學習,把這些代碼下載下傳到本地,配合教程的文字講解,自己動手,以加深了解。

大家如果對教程的每個步驟有任何疑問,歡迎在教程對應的

步驟文章裡給我評論,進行留言。

在本文前一步驟 SAP UI5 初學者教程之九 - 一個 Component 裡,我們把 SAP UI5 Component 的中繼資料,放在了 Component.js 的 metadata 字段裡,如下圖所示:

SAP UI5 初學者教程之十 - 什麼是 SAP UI5 應用的描述符 Descriptor 試讀版

為了将 SAP UI5 應用配置到 Fiori Launchpad 裡,我們必須遵循一些最佳實踐。除了前一步驟介紹的引入 Component.js 支援之外,我們還需引入本文将要讨論的應用描述符 - Application descriptor.

所有特定于 SAP UI5 應用程式的配置設定現在将進一步放在名為 manifest.json 的單獨描述符檔案中。這種做法的好處是清楚地将應用程式編碼(coding)與配置(Configuration)分開,使我們的應用程式在應對将來可能發生的更改時靈活和從容。

SAP UI5 應用開發最佳實踐之一

所有 SAP Fiori 應用程式的内容都實作為元件(Component),并帶有描述符檔案 manifest.json,以便配置在 SAP Fiori Launchpad 中。

SAP Fiori Launchpad 能夠扮演 SAP UI5 應用程式容器的角色,負責執行個體化 SAP UI5 應用程式中的 Component 實作,而無需借助 SAP UI5 應用中的 index.html 檔案。

SAP UI5 應用的描述符 manifest.json 檔案會被 Fiori Launchpad 解析,描述符檔案裡定義的内容會自動被加載。

manifest.json 檔案位于 webapp 目錄下,内容是一個 json 格式的配置對象,這些内容會指引 SAP UI5 架構,運作時如何加載這個描述符檔案描述的 SAP UI5 應用。

manifest.json 的内容分三大部分:

SAP UI5 初學者教程之十 - 什麼是 SAP UI5 應用的描述符 Descriptor 試讀版

關于它們的逐一介紹,以及應用程式需要做哪些修改,才能支援啟用該 manifest.json 檔案,請參考我的專欄文章:SAP UI5 初學者教程之十 - 什麼是 SAP UI5 應用的描述符 Descriptor