温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

发布时间:2020-08-11 22:00:52 来源:ITPUB博客 阅读:181 作者:i042416 栏目:web开发

首先在UI5应用的manifes.json里,定义了UI5应用的入口视图为App:

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

调试器里的pending数组的两个元素:

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

实际上对应了我在App.controller.js里定义的两个依赖:

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

而aModules数组里的两个对象,就是BaseController和JSONModel模块加载后的实例:

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

有经验的开发人员从这些函数列表bindProperty, bindTree, dataLoaded,getJSON等就能得知这个实例是JSONModel的实现。

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

这个注释写的比较清楚,如果factory函数返回不为false的值,则该值需要被赋到module的exported字段去。
from  https://github.com/amdjs/amdjs-api/blob/master/AMD.md
// "If the factory function returns a value (an object, function, or any value that coerces to true),
// then that value should be assigned as the exported value for the module."

UI5模块的加载器:ui5loader.js

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

那么我们应用代码的controller里到底return什么值呢?即BaseController调用extend方法后的返回值。

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

这个返回值在BaseController的基础上,包含了我们应用程序自定义的onInit方法。

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

至此,App.controller.js这个模块就加载完成了。
执行ready之前:

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

ready函数的职责就是把模块实例的state设置成Ready,settled设置成true:

SAP UI5应用入口App.controller.js是如何被UI5框架加载的?

要获取更多Jerry的原创文章,请关注公众号"汪子熙":


SAP UI5应用入口App.controller.js是如何被UI5框架加载的?


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI