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. 入门React和Webpack

    最近在学习React.js,之前都是直接用最原生的方式去写React代码,发现组织起来特别麻烦,之前听人说用Webpack组织React组件得心应手,就花了点时间学习了一下,收获颇丰 说说React ...

  2. <读书笔记>软件调试之道 :问题的核心-如何修复缺陷

    声明:本文档的内容主要来源于书籍<软件调试修炼之道>作者Paul Butcher,属于读书笔记.欢迎转载! 修复缺陷 对于一个好的修复来说,不仅仅是让软件运行正确,还需要为将来奠定基础.一 ...

  3. Set,List,Map,Vector,ArrayList的区别(转)

    JAVA的容器---List,Map,Set Collection ├List │├LinkedList │├ArrayList │└Vector │ └Stack └Set Map ├Hashtab ...

  4. requirejs的使用

    requirejs的优点: 1.防止在js的加载过程中,阻止页面的渲染: 2.可以引入多个js文件: 3.可以写出重复使用的js模块: 4.有效的防止命名的冲突,通过将变量分装在模块中的方式实现: r ...

  5. VC++ 6.0远程调试配置

    VC开发环境之所以提供远程调试的能力,是因为有些情况下单机调试会让你崩溃掉...比如,调试GUI程序的WM_PAINT消息,因为要单步调试,所以调试器会对界面的重绘产生副作用(Heisenberg不确 ...

  6. 研究SVM时安装的一些工具的方法

    本文是个人存档,不介绍研究SVM相关内容. 1.bamboo在fedora19下 哪一行编译时报错,就注释掉 php插件不用装 提示ERROR: libcrfpp.so.0: cannot open ...

  7. linux 学习7 用户管理相关文件 r

    7.1.用户配置文件 7.2.用户管理相关文件 7.3.用户管理命令 7.4.用户组管理命令 删除用户userdel [root@localhost ~]# userdel [-r] 用户名 //一定 ...

  8. WPF 大数据加载过程中的等待效果——圆圈转动

    大家肯定遇到过或将要遇到加载大数据的时候,如果出现长时间的空白等待,一般人的概念会是:难道卡死了? 作为一个懂技术的挨踢技术,即使你明知道数据量太大正在加载,但是假如看不到任何动静,自己觉得还是一种很 ...

  9. (转载)iOS 极光推送SDK 集成指南

    iOS SDK 集成指南 使用提示 本文匹配的 SDK版本:r1.2.5 以后. 查看最近更新了解最新的SDK更新情况. 产品功能说明 极光推送(JPush)是一个端到端的推送服务,使得服务器端消息能 ...

  10. c#利用反射获取对象属性值

    public static string GetObjectPropertyValue<T>(T t, string propertyname){     Type type = type ...