likes
comments
collection
share

SAP UI5 应用开发教程之七十六 - 如何实现 SAP UI5 的 Lazy Loading(延

作者站长头像
站长
· 阅读数 19

一套适合 SAP UI5 初学者循序渐进的学习教程

教程目录

说明

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 等等来标识,例如步骤 1 的源代码在这里

SAP UI5 应用开发教程之七十六 - 如何实现 SAP UI5 的 Lazy Loading(延

每一个步骤均是前一步骤的基础上,添加了若干新特性。建议零基础或者对 SAP UI5 知之甚少的初学者,按照顺序从第一个步骤开始循序渐进地学习,把这些代码下载到本地,配合教程的文字讲解,自己动手,以加深理解。

大家如果对教程的每个步骤有任何疑问,欢迎在教程对应的步骤文章里给我评论,进行留言。

笔者曾经发表过一些关于 SAP UI5 List 控件和 SAP UI5 Module Lazy Loading(又称延迟加载,懒加载)的实现机制:

延迟加载的对立面是贪婪加载(Eager Loading)。所谓贪婪加载,是应用初始化时,一次性加载尽可能多的业务数据,哪怕这些业务数据可能某些用户并不会真正使用到。

看个实际的例子。下面是本教程第 72 个步骤开发的页面:

SAP UI5 应用开发教程之七十二 - SAP UI5 页面路由的动画效果设置

在 Employee 的简历视图页面,有4个标签页可供点击。默认显示第一个标签页 Info 的内容。

SAP UI5 应用开发教程之七十六 - 如何实现 SAP UI5 的 Lazy Loading(延

步骤 72 采取的是默认的贪婪加载模式,即无论用户是否点击上图图例 2,3,4 对应的三个标签页,默认情况下,这4个标签页的内容(包括视图和业务数据),会在应用初始化时提前加载。

我们开启 SAP UI5 调试模式,来观察这个默认贪婪加载模式的效果。

在应用 url 后面加上 ?sap-ui-debug=true 的参数,重新启动应用:

http://localhost:8080/webapp/...

Employee 的简历视图里,四个标签页虽然默认只打开了 Info 标签页,但是该页面打开的时候,后三个标签页对应的页面,其实也一并加载并渲染了。

这是因为这四个标签页的 Layout 设计,是静态嵌入在 Resume.view.xml 实现文件内部的,属于该 xml 文件的一部分。只要这个视图文件被加载,则 4 个标签页的全部内容,会随着 Resume.view.xml 一起被加载。

SAP UI5 应用开发教程之七十六 - 如何实现 SAP UI5 的 Lazy Loading(延

贪婪加载模式下,当从默认的 Info 标签页切换到其他三个标签页后,Network 观测不到任何数据加载,因为这些标签页对应的 Layout 布局信息,已经作为 Resume.view.xml 的一部分,在之前就已经加载了。

SAP UI5 应用开发教程之七十六 - 如何实现 SAP UI5 的 Lazy Loading(延

我们再看通过本步骤实现了 Lazy Loading 后的效果。

  • 当且仅当点击 Hobbies 标签时,才触发 Hobbies 视图的加载;

SAP UI5 应用开发教程之七十六 - 如何实现 SAP UI5 的 Lazy Loading(延

  • 当且仅当点击 Notes 标签时,才触发 Notes 视图的加载;

SAP UI5 应用开发教程之七十六 - 如何实现 SAP UI5 的 Lazy Loading(延

因此,SAP UI5 应用程序视图延迟加载的思路就是,将一个大而全的视图,按照业务将其进行细粒度拆分,形成小而专的若干视图片段,并且一次仅加载用户真正需要使用到的那些视图片段。

下面是具体的实现步骤。