Extjs4以前的版本没有动态加载类的方式,这样开发程序的时候加载很多的js会导致加载变慢,由于本人一直使用extjs3的版本进行开发,于是简单实现了一个动态加载类的管理器,使用方式与extjs4的方式有些类似,在每一个类中需要使用其他类的时候像java一样先improt再使用。先看使用方式:
Ext.setPath("ThinkOA", "app");//将命名空间ThinkOA映射成webContent下的app文件夹,这样凡ThinkOA的命名空间的类都会去app目录下加载
Ext.setPath("Ext.ux", "resources/ux");//将命名空间Ext.ux映射成webContent下的resources/ux文件夹路径,这样凡Ext.ux的命名空间的类都会去resources/ux目录下加载
Ext.loadJs("ThinkOA/ns.js");//加载ns.js文件
Ext.loadJs("ThinkOA/constant.js");
Ext.require("ThinkOA.Viewport");//导入自定义类ThinkOA.Viewport 需要保证app目录下有名称为Viewprot.js文件,里面的类名称必须是ThinkOA.Viewport
Ext.require("ThinkOA.LoginWindow");//导入自定义类ThinkOA.LoginWindow
new ThinkOA.LoginWindow({
isDebug: false,
loginUrl: "login.do",//Ext.ParamMgr.getValue("login.url"),
listeners: {
scope: this,
submit: function(win, jsonObject) {
if (jsonObject.success) {
new ThinkOA.Viewport({
});
win.close();
}else {
Ext.MessageBox.alert("提示",jsonObject.message);
}
}
}
}).show();
按照这样的方式,当需要引入一个类的时候直接调用Ext.require()方法即可,这样在使用的时候就会动态去加载这个类,当然也可以动态的去引入一个不是类的js文件,调用Ext.loadJs()即可实现动态加载,现在下面给出动态加载js实现的代码,在这里采用ajax去请求js文件,然而ajax的方式都是异步的,这样就不能保证需要使用的类还没加载完就执行后面的代码,于是先实现一个同步的ajax方法,代码如下:
/** * 扩张Ext.Ajax对象,增加同步请求方法 */ Ext.apply(Ext.Ajax, { /** * 同步请求方法,将阻塞 */ syncRequest : function(cfg) { cfg = Ext.apply({ success : Ext.emptyFn, failure : Ext.emptyFn }, cfg) var obj; if (window.ActiveXObject) { obj = new ActiveXObject('Microsoft.XMLHTTP'); } else if (window.XMLHttpRequest) { obj = new XMLHttpRequest(); } obj.open('POST', cfg.url, false); obj.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); obj.send(cfg.params); var argument = cfg.argument || {}; if (obj.status == 200) { cfg.success.call(cfg.scope || this, obj,argument); } else if(obj.status == 404){ // Ext.MessageBox.alert(cfg.url+"不存在!") cfg.failure.call(cfg.scope || this, obj,argument); }else { cfg.failure.call(cfg.scope || this, obj,argument); } // var result = Ext.util.JSON.decode(obj.responseText); } });
有了此同步请求方法后,下面的js动态加载管理器就很容易实现,当加载一次的js文件就不会再加载,代码:
/** * js加载管理器 */ Ext.JsMgr = Ext.extend(Object, { timeout : 30, scripts : {}, disableCaching : true, paths : {}, setPath : function(dest, target) { this.paths[dest] = target; }, loadClass : function(className) { for (var p in this.paths) { className = className.replace(p, this.paths[p]) } var jsUrl = className.split(".").join("/") + ".js"; if (!this.scripts[className]) { //同步请求js文件 Ext.Ajax.syncRequest({ url : jsUrl, success : this.processSuccess, failure : this.processFailure, scope : this, timeout : (this.timeout * 1000), disableCaching : this.disableCaching, argument : { 'url' : className } }); } }, loadJavaScript : function(filepath) { var className = filepath.replace(".js","").split("/").join("."); this.loadClass(className); }, processSuccess : function(response,argument) { this.scripts[argument.url] = true; window.execScript ? window .execScript(response.responseText) : window .eval(response.responseText); }, processFailure : function() { } }) Ext.JsMgr = new Ext.JsMgr(); Ext.setPath = function(ns,path) { Ext.JsMgr.setPath(ns,path) ; } Ext.require = function() { Ext.JsMgr.loadClass(arguments[0]); }; Ext.loadJs = function() { Ext.JsMgr.loadJavaScript(arguments[0]) }
到此js加载管理器实现完成,目前只是先随便写了个哉项目中使用了下,还比较方便,不再需要大量的引入js,这样就可以实现按需加载,只是目前采用同步加载方式效率不会太高,以后考虑改成异步加载,提高加载速度。最后给出完整代码:
(function() {
/**
* 扩张Ext.Ajax对象,增加同步请求方法
*/
Ext.apply(Ext.Ajax, {
/**
* 同步请求方法,将阻塞
*/
syncRequest : function(cfg) {
cfg = Ext.apply({
success : Ext.emptyFn,
failure : Ext.emptyFn
}, cfg)
var obj;
if (window.ActiveXObject) {
obj = new ActiveXObject('Microsoft.XMLHTTP');
} else if (window.XMLHttpRequest) {
obj = new XMLHttpRequest();
}
obj.open('POST', cfg.url, false);
obj.setRequestHeader('Content-Type',
'application/x-www-form-urlencoded');
obj.send(cfg.params);
var argument = cfg.argument || {};
if (obj.status == 200) {
cfg.success.call(cfg.scope || this, obj,argument);
} else if(obj.status == 404){
// Ext.MessageBox.alert(cfg.url+"不存在!")
cfg.failure.call(cfg.scope || this, obj,argument);
}else {
cfg.failure.call(cfg.scope || this, obj,argument);
}
// var result = Ext.util.JSON.decode(obj.responseText);
}
});
Ext.override(Ext.mgr.CompMgr,{
getInstance : function(id, override){
var instance, comp = this.get(id);
if(comp){
Ext.require(comp.className);//先加载类
instance = new (comp.getClass())(Ext.apply(comp.getConfig(), override));
}
return instance;
}
})
/**
* js加载管理器
*/
Ext.JsMgr = Ext.extend(Object, {
timeout : 30,
scripts : {},
disableCaching : true,
paths : {},
setPath : function(dest, target) {
this.paths[dest] = target;
},
loadClass : function(className) {
for (var p in this.paths) {
className = className.replace(p, this.paths[p])
}
var jsUrl = className.split(".").join("/") + ".js";
if (!this.scripts[className]) {
//同步请求js文件
Ext.Ajax.syncRequest({
url : jsUrl,
success : this.processSuccess,
failure : this.processFailure,
scope : this,
timeout : (this.timeout * 1000),
disableCaching : this.disableCaching,
argument : {
'url' : className
}
});
}
},
loadJavaScript : function(filepath) {
var className = filepath.replace(".js","").split("/").join(".");
this.loadClass(className);
},
processSuccess : function(response,argument) {
this.scripts[argument.url] = true;
window.execScript ? window
.execScript(response.responseText) : window
.eval(response.responseText);
},
processFailure : function() {
}
})
Ext.JsMgr = new Ext.JsMgr();
Ext.setPath = function(ns,path) {
Ext.JsMgr.setPath(ns,path) ;
}
Ext.require = function() {
Ext.JsMgr.loadClass(arguments[0]);
};
Ext.loadJs = function() {
Ext.JsMgr.loadJavaScript(arguments[0])
}
})();
源码下载地址:http://download.csdn.net/detail/ybhanxiao/7804811