Ext JS 4的倒数:动态加载和新的类机制 Count down to Ext JS 4: Dynamic Loading and New Class System (下)

January 19, 2011 by Ed Spencer 翻译 Ext中文网(ajaxjs.com) Frank
/blog/2011/01/19/countdown-to-ext-js-4-dynamic-loading-and-new-class-system

动态加载 Dynamic Loading

在我们初步了解完“类机制”的内容后,我们接着要揭开的将是于Ext JS 4中同样也是完全崭新的一项功能:动态加载(Dynamic Loading)。长久以来,包括前期ExtJS的各个版本中,尽管允许裁剪,不过通常使用之前它一定要加载整个框架。好像创建一个普通的Ext.Window,得必须下载整份的ext-all.js源文件,否则便会不能工作。Ext JS 4的动态加载便是围绕这个技术点而考虑推出的。普通的一个例子如下:

此处我们说明一下上述过程,就是要求Ext JS加载Ext.Window类,加载完之后调用函数,创建Window实例。Ext.require函数可支持数组的参数,传入多个要加载的类。用起来十分方便,当然背后隐藏了相当多的细节。Ext JS 4的动态加载这种方式不需要服务端的安装什么,纯客户端的。值得一提的是,它能自动计算依赖关系,下载所需的类。比如一个Ext.Window的类像是这样的:

动态加载换种说法是“按需加载”。

只要Ext JS加载Ext.Windows类,便会分析其中的依赖关系,需要什么什么的extend、什么的requires、什么的mixin……在创建Window实例之前必须确定所需的包已经在页面资源中,否则不能创建成功。总之凡是需要的就不能错过。实际上,加载器(Loader)通过字符串的名称便会清楚每一个类所在包,个中的原理正是基于语言的“反射”。在这里例子中,依赖的结果将会是下面所示的文件:

  • src/Window.js
  • src/Panel.js
  • src/util/MixedCollection.js
  • src/util/Draggable.js 

加载器加载的过程是递归的,因此无论嵌套多少个层次都会保证把所需的包文件加载回来。但这里我们仍要强调一点,在产品上线阶段,却应该避免逐个逐个下载js文件,因为比下载单个文件费时多了。于是这样的话,相比较动态加载的分散js文件,便浮现了一个问题出来,那就是,你得晓得,哪些文件是要经过全体打包;哪些文件适宜分散来动态加载;什么阶段采取什么的策略。例如只需要一个对话框的部件,显然ext-all-debug.js加载太大了,下载太久了,卸下不需要的包自然好些,就应采用更加“智能”的动态加载。

对于调试阶段而言,若面对一份ext-all-debug.js文件就超过六万行的代码则十分困难。打点、跟踪告诉你ext-all-debug.js文件第47657行好像作用不太,仍然犯晕……如果经过动态加载器,便会定位在src/data/JsonReader.js文件的第56行,报告每份源文件的准确行数。

这可以说是巨大的进步以有利于您调试您的程序。不过在本地开发阶段还是适宜加载全部源文件,而加载器因此提供了检测死锁(DeadLock Dection),能够同步或异步地加载文件。

如果新系统新内容所做的一切不能迎合您,没有关系,建议用户采用旧方式,因为新的类系统这一边也是做到了彻底的向后兼容(completely backwards compatible),所以用户大可使用旧的方式方法。Ext.extend保留旧的方式创建任意类,而且依然提供包含整个框架内容的ext-all.js。

posted on 2011-01-27 11:00  java-time  阅读(509)  评论(0编辑  收藏  举报