Extjs4以前的版本没有动态加载类的方式,这样开发程序的时候加载很多的js会导致加载变慢,由于本人一直使用extjs3的版本进行开发,于是简单实现了一个动态加载类的管理器,使用方式与extjs4的方式有些类似,在每一个类中需要使用其他类的时候像java一样先improt再使用。先看使用方式:

  1. Ext.setPath("ThinkOA", "app");//将命名空间ThinkOA映射成webContent下的app文件夹,这样凡ThinkOA的命名空间的类都会去app目录下加载
  2. Ext.setPath("Ext.ux", "resources/ux");//将命名空间Ext.ux映射成webContent下的resources/ux文件夹路径,这样凡Ext.ux的命名空间的类都会去resources/ux目录下加载
  3. Ext.loadJs("ThinkOA/ns.js");//加载ns.js文件
  4. Ext.loadJs("ThinkOA/constant.js");
  5. Ext.require("ThinkOA.Viewport");//导入自定义类ThinkOA.Viewport 需要保证app目录下有名称为Viewprot.js文件,里面的类名称必须是ThinkOA.Viewport
  6. Ext.require("ThinkOA.LoginWindow");//导入自定义类ThinkOA.LoginWindow
  7. new ThinkOA.LoginWindow({
  8. isDebug: false,
  9. loginUrl: "login.do",//Ext.ParamMgr.getValue("login.url"),
  10. listeners: {
  11. scope: this,
  12. submit: function(win, jsonObject) {
  13. if (jsonObject.success) {
  14. new ThinkOA.Viewport({
  15. });
  16. win.close();
  17. }else {
  18. Ext.MessageBox.alert("提示",jsonObject.message);
  19. }
  20. }
  21. }
  22. }).show();

js文件目录结构如下:

按照这样的方式,当需要引入一个类的时候直接调用Ext.require()方法即可,这样在使用的时候就会动态去加载这个类,当然也可以动态的去引入一个不是类的js文件,调用Ext.loadJs()即可实现动态加载,现在下面给出动态加载js实现的代码,在这里采用ajax去请求js文件,然而ajax的方式都是异步的,这样就不能保证需要使用的类还没加载完就执行后面的代码,于是先实现一个同步的ajax方法,代码如下:

  1. /**
  2. * 扩张Ext.Ajax对象,增加同步请求方法
  3. */
  4. Ext.apply(Ext.Ajax, {
  5. /**
  6. * 同步请求方法,将阻塞
  7. */
  8. syncRequest : function(cfg) {
  9. cfg = Ext.apply({
  10. success : Ext.emptyFn,
  11. failure : Ext.emptyFn
  12. }, cfg)
  13. var obj;
  14. if (window.ActiveXObject) {
  15. obj = new ActiveXObject('Microsoft.XMLHTTP');
  16. } else if (window.XMLHttpRequest) {
  17. obj = new XMLHttpRequest();
  18. }
  19. obj.open('POST', cfg.url, false);
  20. obj.setRequestHeader('Content-Type',
  21. 'application/x-www-form-urlencoded');
  22. obj.send(cfg.params);
  23. var argument = cfg.argument || {};
  24. if (obj.status == 200) {
  25. cfg.success.call(cfg.scope || this, obj,argument);
  26. } else if(obj.status == 404){
  27. //                      Ext.MessageBox.alert(cfg.url+"不存在!")
  28. cfg.failure.call(cfg.scope || this, obj,argument);
  29. }else {
  30. cfg.failure.call(cfg.scope || this, obj,argument);
  31. }
  32. // var result = Ext.util.JSON.decode(obj.responseText);
  33. }
  34. });

有了此同步请求方法后,下面的js动态加载管理器就很容易实现,当加载一次的js文件就不会再加载,代码:

  1. /**
  2. * js加载管理器
  3. */
  4. Ext.JsMgr = Ext.extend(Object, {
  5. timeout : 30,
  6. scripts : {},
  7. disableCaching : true,
  8. paths : {},
  9. setPath : function(dest, target) {
  10. this.paths[dest] = target;
  11. },
  12. loadClass : function(className) {
  13. for (var p in this.paths) {
  14. className = className.replace(p, this.paths[p])
  15. }
  16. var jsUrl = className.split(".").join("/") + ".js";
  17. if (!this.scripts[className]) {
  18. //同步请求js文件
  19. Ext.Ajax.syncRequest({
  20. url : jsUrl,
  21. success : this.processSuccess,
  22. failure : this.processFailure,
  23. scope : this,
  24. timeout : (this.timeout * 1000),
  25. disableCaching : this.disableCaching,
  26. argument : {
  27. 'url' : className
  28. }
  29. });
  30. }
  31. },
  32. loadJavaScript : function(filepath) {
  33. var className  = filepath.replace(".js","").split("/").join(".");
  34. this.loadClass(className);
  35. },
  36. processSuccess : function(response,argument) {
  37. this.scripts[argument.url] = true;
  38. window.execScript ? window
  39. .execScript(response.responseText) : window
  40. .eval(response.responseText);
  41. },
  42. processFailure : function() {
  43. }
  44. })
  45. Ext.JsMgr = new Ext.JsMgr();
  46. Ext.setPath = function(ns,path) {
  47. Ext.JsMgr.setPath(ns,path) ;
  48. }
  49. Ext.require = function() {
  50. Ext.JsMgr.loadClass(arguments[0]);
  51. };
  52. Ext.loadJs = function() {
  53. Ext.JsMgr.loadJavaScript(arguments[0])
  54. }

到此js加载管理器实现完成,目前只是先随便写了个哉项目中使用了下,还比较方便,不再需要大量的引入js,这样就可以实现按需加载,只是目前采用同步加载方式效率不会太高,以后考虑改成异步加载,提高加载速度。最后给出完整代码:

  1. (function() {
  2. /**
  3. * 扩张Ext.Ajax对象,增加同步请求方法
  4. */
  5. Ext.apply(Ext.Ajax, {
  6. /**
  7. * 同步请求方法,将阻塞
  8. */
  9. syncRequest : function(cfg) {
  10. cfg = Ext.apply({
  11. success : Ext.emptyFn,
  12. failure : Ext.emptyFn
  13. }, cfg)
  14. var obj;
  15. if (window.ActiveXObject) {
  16. obj = new ActiveXObject('Microsoft.XMLHTTP');
  17. } else if (window.XMLHttpRequest) {
  18. obj = new XMLHttpRequest();
  19. }
  20. obj.open('POST', cfg.url, false);
  21. obj.setRequestHeader('Content-Type',
  22. 'application/x-www-form-urlencoded');
  23. obj.send(cfg.params);
  24. var argument = cfg.argument || {};
  25. if (obj.status == 200) {
  26. cfg.success.call(cfg.scope || this, obj,argument);
  27. } else if(obj.status == 404){
  28. //                      Ext.MessageBox.alert(cfg.url+"不存在!")
  29. cfg.failure.call(cfg.scope || this, obj,argument);
  30. }else {
  31. cfg.failure.call(cfg.scope || this, obj,argument);
  32. }
  33. // var result = Ext.util.JSON.decode(obj.responseText);
  34. }
  35. });
  36. Ext.override(Ext.mgr.CompMgr,{
  37. getInstance : function(id, override){
  38. var instance, comp = this.get(id);
  39. if(comp){
  40. Ext.require(comp.className);//先加载类
  41. instance = new (comp.getClass())(Ext.apply(comp.getConfig(), override));
  42. }
  43. return instance;
  44. }
  45. })
  46. /**
  47. * js加载管理器
  48. */
  49. Ext.JsMgr = Ext.extend(Object, {
  50. timeout : 30,
  51. scripts : {},
  52. disableCaching : true,
  53. paths : {},
  54. setPath : function(dest, target) {
  55. this.paths[dest] = target;
  56. },
  57. loadClass : function(className) {
  58. for (var p in this.paths) {
  59. className = className.replace(p, this.paths[p])
  60. }
  61. var jsUrl = className.split(".").join("/") + ".js";
  62. if (!this.scripts[className]) {
  63. //同步请求js文件
  64. Ext.Ajax.syncRequest({
  65. url : jsUrl,
  66. success : this.processSuccess,
  67. failure : this.processFailure,
  68. scope : this,
  69. timeout : (this.timeout * 1000),
  70. disableCaching : this.disableCaching,
  71. argument : {
  72. 'url' : className
  73. }
  74. });
  75. }
  76. },
  77. loadJavaScript : function(filepath) {
  78. var className  = filepath.replace(".js","").split("/").join(".");
  79. this.loadClass(className);
  80. },
  81. processSuccess : function(response,argument) {
  82. this.scripts[argument.url] = true;
  83. window.execScript ? window
  84. .execScript(response.responseText) : window
  85. .eval(response.responseText);
  86. },
  87. processFailure : function() {
  88. }
  89. })
  90. Ext.JsMgr = new Ext.JsMgr();
  91. Ext.setPath = function(ns,path) {
  92. Ext.JsMgr.setPath(ns,path) ;
  93. }
  94. Ext.require = function() {
  95. Ext.JsMgr.loadClass(arguments[0]);
  96. };
  97. Ext.loadJs = function() {
  98. Ext.JsMgr.loadJavaScript(arguments[0])
  99. }
  100. })();

源码下载地址:http://download.csdn.net/detail/ybhanxiao/7804811

关于实现Extjs动态加载类的方式实现的更多相关文章

  1. tomcat 5.5 动态加载类

    转载于:http://www.itxuexiwang.com/a/javadianzishu/tomcat/2016/0225/161.html?1456480735 开发使用的是tomcat5.5. ...

  2. [javaSE] 反射-动态加载类

    Class.forName(“类的全称”) ①不仅表示了类的类类型,还代表了动态加载类 ②请大家区分编译,运行 ③编译时刻加载类是静态加载类,运行时刻加载类是动态加载类 Ⅰ所有的new对象都是静态加载 ...

  3. java动态加载类和静态加载类笔记

    JAVA中的静态加载类是编译时刻加载类  动态加载类指的是运行时刻加载类 二者有什么区别呢 举一个例子  现在我创建了一个类  实现的功能假设为通过传入的参数调用具体的类和方法 class offic ...

  4. Java动态加载类在功能模块开发中的作用

    Java中我们一般会使用new关键字实例化对象然后调用该对象所属类提供的方法来实现相应的功能,比如我们现在有个主类叫Web类这个类中能实现各种方法,比如用户注册.发送邮件等功能,代码如下: /* * ...

  5. java reflect 初始学习 动态加载类

    首先要理解Class类: 在java 的反射中,Class.forName("com.lilin.Office") 使用类的全名,这样获取,不仅仅表示了类的类类型,同时还代表着类的 ...

  6. Java运行时动态加载类之ClassLoader

    https://blog.csdn.net/fjssharpsword/article/details/64922083 *************************************** ...

  7. java反射动态加载类Class.forName();

    1,所有的new出来的对象都是静态加载的,在程序编译的时候就会进行加载.而使用反射机制Class.forName是动态加载的,在运行时刻进行加载. 例子:直接上两个例子 public class Ca ...

  8. 反射01 Class类的使用、动态加载类、类类型说明、获取类的信息

    0 Java反射机制 反射(Reflection)是 Java 的高级特性之一,是框架实现的基础. 0.1 定义 Java 反射机制是在运行状态中,对于任意一个类,都能够知道这个类的所有属性和方法:对 ...

  9. Class类动态加载类的用法

    编译时刻加载类出现的问题:一个功能有错,所有功能都用不了 动态加载类:

随机推荐

  1. Struts2环境搭建

    1,从http://struts.apache.org  官网下载struts2的源码,最新的源码是2.5版本的,但是考虑到网上2.3版本的教程比较多,所以我下载了一个2.3版本的struts. 2, ...

  2. 笔试常考的Java基础

    1. Socket编程:ServerSocket (int port) :Creates a server socket, bound to the specified port. Socket(In ...

  3. 解决vs2008无法切换设计视图的问题

    在 Visual Studio 2008的编辑一个web页面的时候,“源视图”(Source View), 你可以自定义设计视图(Design View)为默认视图. 方法如下: 菜单:工具+选项+h ...

  4. EBS中启用OAF页面个性化三个配置

    启用OAF页面个性化三个配置(Profiles) FND:诊断英文为FND: Diagnostics,用于设置是否显示“关于此页” 个性化自助定义英文为Personalize Self-Service ...

  5. 利用Sql实现将指定表数据导入到另一个数据库示例

    因为工作中经常需要将数据从一个数据库导入到另一个数据库中,所以将这个功能写成一个存储过程,以方便调用.现在粘贴出来供大家参考: 注意:1,以下示例中用到了syscolumns,sysobjects等系 ...

  6. TextVeiw 的 No package identifier when getting value for resource numb

    tv_title,tv_detail,tv_comment都是TextView; newInfo.getComment()得到的是int类型 tv_title.setText(newInfo.getT ...

  7. 使用WebClient 或者 HttpWebRequest均报:"The Remote name can't be solved"

    错误原因: 未配置代理服务器设置的问题, 需要在配置节做如下操作. ============================================ 文章编号: 318140 - 查看本文应用 ...

  8. windows下手动安装和配置xamarin

    安装xamarin xamarin官方给出了两种安装方式,自动安装和手动安装. 自动安装比较简单,到http://xamarin.com/download下载xamarininstaller.exe ...

  9. Acadia Lab 6 轮盘游戏机

    WRTnode 肯定不是亲生的... 果断转投Acadia —.— 不是国军不给力,奈何共军有高达 为啥不转树莓派?因为选做实验肯定有很多人用树莓派做...我抢不过他们,只能挑点冷门的蹭分_(:з」 ...

  10. angular中ng-model,返回数据,拆分数据,展示,名称相同,重新赋值会有冲突

    本问题出在angular,1.X版本,我用的是1.5的版本: 问题原因: <input type="number" ng-mode="a" /> & ...