87,921
社区成员
发帖
与我相关
我的任务
分享
[/code][code=css]
Object.prototype.copy=function(extendObj){
if(!App.isObject(this))throw {message:'对象不支持此属性或方法'};
if(App.isObject(extendObj))for(var p in extendObj)this[p]=extendObj[p];
}
Object.prototype.copyIf=function(extendObj){
if(!App.isObject(this))throw {message:'对象不支持此属性或方法'};
if(App.isObject(extendObj))for(var p in extendObj)if(App.isUndefined(this[p]))this[p]=extendObj[p];
}
String.prototype.trim=function(){return this.replace(/^\s+|\s+$/g,'')};
var App={
_getType:function(v){return Object.prototype.toString.apply(v)},
getType:function(v){if(v===undefined)return '[object Undefined]';else if(v===null)return '[object Null]';return App._getType(v)},
isFunction:function(v){return App._getType(v)==='[object Function]'},
isObject:function(v){return App._getType(v)==='[object Object]'},
isArray:function(v){return App._getType(v)==='[object Array]'},
isDate:function(v){return App._getType(v)==='[object Date]'},
isString:function(v){return App._getType(v)==='[object String]'},
isBoolean:function(v){return App._getType(v)==='[object Boolean]'},
isNumber:function(v){return App._getType(v)==='[object Number]'},
isInt:function(v){return App.isNumber(v) && (v+'').indexOf('.')<0},
isUndefined:function(v){return v===undefined},
isNull:function(v){return v===null},
isBlankString:function(v){return App.isString(v) && v.trim().length==0},
isNotBlankString:function(v){return App.isString(v) && v.trim().length>0},
isEmptyObject:function(v){return App.isObject(v) && (function(x){for(var p in x)return false;return true}(v))},
isNotEmptyObject:function(v){return App.isObject(v) && (function(x){for(var p in x)return true;return false}(v))}
};
var AJAX={};
AJAX.copy({
/**
* 建立一个ajax对象
*/
createAjax:function(){
var xmlHttpRequestObj;
try{
xmlHttpRequestObj=new XMLHttpRequest();
}
catch(e){
try{
xmlHttpRequestObj=new ActiveXObject("Msxml2.XMLHTTP");
}
catch(e){
try{
xmlHttpRequestObj=new ActiveXObject("Microsoft.XMLHTTP");
}
catch(e){
return false;
}
}
}
return xmlHttpRequestObj;
},
/**
* 一个ajax的请求操作
* @param url
* ajax访问的地址
* @param params
* 传递的参数
* @param callback
* ajax访问后的回调函数
* @param submitMode
* 提交的方式,默认为post
* @param async
* 执行ajax的模式,异步或同步,默认为异步,设置async===false表示为同步
*/
request:function(url,params,callback,submitMode,async){
var ajax=this.createAjax();
if(!ajax)return;
ajax.onreadystatechange=function()//ajax的关键函数,每当发送请求时ajax的状态一改变就执行
{
if (ajax.readyState==4 && ajax.status==200)//4表示ajax请求完成,200表示请求得到执行
{
if(App.isFunction(callback)){callback(ajax.responseText)}
}
}
/**
* 打开请求,第一个参数为请求的方式,包括post和get两种,常用post;
* 第二个参数为请求的url,前面定义的那个;
* 第三个参数为ajax是同步调用还是异步调用,同步调用表示本次请求完成后才执行请求后的代码,否则边请求边执行页面的其他程序,ture表示异步
*/
if(submitMode==='GET' && App.isNotBlankString(params))url+='?'+params;
ajax.open(submitMode||'POST',url,async!==false);
//发送请求,参数为字符串,当请求方式为post时有效
if(submitMode==='GET')ajax.send();
else{
ajax.setRequestHeader("Content-type","application/x-www-form-urlencoded");
ajax.send(params);
}
return ajax;
},
/**
* 中断一个ajax
*/
abort:function(ajax){ajax.abort()}
});
var request=AJAX.request('xxx.jsp|asp|aspx|php','',function(result){alert(result)});
//AJAX.abort(request);