• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

一个Ajax类_jquery

jquery 搞代码 7年前 (2018-06-12) 83次浏览 已收录 0个评论

一个Ajax类
function Ajax(url,recvT,stringS,resultF) {
    this.url = url;
    this.stringS = stringS;
    this.xmlHttp = this.createXMLHttpRequest();
    if (this.xmlHttp == null) {
        alert(“erro”);
        return;
    }
    var objxml = this.xmlHttp;
    objxml.onreadystatechange = function (){Ajax.handleStateChange(objxml,recvT,resultF)};
}

Ajax.prototype.createXMLHttpRequest = function() {
    try { return new ActiveXObject(“Msxml2.XMLHTTP”);    } catch(e) {}
    try { return new ActiveXObject(“Microsoft.XMLHTTP”); } catch(e) {}
    try { return new XMLHttpRequest();                   } catch(e) {}
    return null;
}

Ajax.prototype.createQueryString = function () {
    var queryString = this.stringS;
    return queryString;
}

Ajax.prototype.get = function () {
    url = this.url;
    var queryString = url+”?timeStamp=” + new Date().getTime() + “&” + this.createQueryString();
    this.xmlHttp.open(“GET”,queryString,true);
    this.xmlHttp.send(null);
}

Ajax.prototype.post = function() {
    url = this.url;
    var url = url + “?timeStamp=” + new Date().getTime();
    var queryString = this.createQueryString();
    this.xmlHttp.open(“POST”,url,true);
    this.xmlHttp.setRequestHeader(“Content-Type”,”application/x-www-form-urlencoded”);
    this.xmlHttp.send(queryString);
}
   
Ajax.handleStateChange = function (xmlHttp,recvT,resultF) {
    if (xmlHttp.readyState == 4) {
        if (xmlHttp.status == 200) {
        resultF(recvT?xmlHttp.responseXML:xmlHttp.responseText);
        } else {
        alert(“您所请求的页面有异常。”);
        }
    }
}

使用方法
var classajax = new Ajax(url,recvT,stringS,resultF);
classajax.post();//post方式发送数据
classajax.get();//get方式发送数据
url发送地址 recvT 接受数据类型 0为xml 1为text resultF 返回结果处理函数


var ajax1 = new Ajax(“1.asp”,0,”id=”+id,bacal);
ajax1.post();
function bacal(rexm){
//返回数据处理函数;
}
———————————————————–

Quertion:
其中的这句代码resultF(recvT?xmlHttp.responseXML:xmlHttp.responseText);
看不明白,有那位大哥大姐给解释解释?
当 recvT 为0 时,返回的是个对象,我不知道该如何使用,或者该对象有什么属性?
这句话的中的 ? 和 : 在这里是什么格式,什么作用?

Answer:
三元运算符。
(A>B)?1:0
意思是: 若A>B ,则1 否则 0

resultF(recvT?xmlHttp.responseXML:xmlHttp.responseText);
根据字面意思看是:
接受数据函数: resultF
接受到的数据:recvT(应该是Recived Text的缩写)
整个意思:将返回的数据以xmlHttp.responseXML 或 xmlHttp.responseText的格式返回

欢迎大家阅读《一个Ajax类_jquery,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:一个Ajax类_jquery

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址