码迷,mamicode.com
首页 > 其他好文 > 详细

ajax重构XMLHttpRequest

时间:2014-07-09 13:57:08      阅读:225      评论:0      收藏:0      [点我收藏+]

标签:style   blog   http   color   os   cti   

//重构XMLHttpRequest
var
net = new Object(); //名字空間對象 net.READY_STATE_UNINITIALIZED = 0; net.READY_STATE_LOADING = 1; net.READY_STATE_LOADED = 2; net.READY_STATE_INTERACTIVE = 3; net.READY_STATE_COMPLETE = 4; net.ContentLoader = function(url, onload, onerror) { //構造函數 this.url = url; this.req = null; this.onload = onload; this.onerror = (onerror) ? onerror : this.defaultError; this.loadXMLDoc(url); } net.ContentLoader.prototype = { loadXMLDoc: function(url) { //重新命名的initXMLHttpRequest函數 if (window.XMLHttpRequest) { //重構過的loadXML函數 this.req = new XMLHttpRequest(); } else if (window.ActiveXObject) { this.req = new ActiveXObject("Microsoft.XMLHTTP"); } if (this.req) { try { var loader = this; this.req.onreadystatechange = function() { loader.onReadyState.call(loader); } this.req.open(‘GET‘, url, true); //重構過的sendRequest函數 this.req.send(null); } catch (err) { this.onerror.call(this); } } }, onReadyState: function() { //重構過的回調函數 var req = this.req; var ready = req.readyState; if (ready == net.READY_STATE_COMPLETE) { var httpStatus = req.status; if (httpStatus == 200 || httpStatus == 0) { this.onload.call(this); } else { this.onerror.call(this); } } }, defaultError: function() { alert("error fetching data!" + "\n\nreadyState:" + this.req.readyState + "\nstatus:" + this.req.status + "\nheaders:" + this.req.getAllResponseHeaders()); } } function myCallBack() { alert{this.url +" loaded! Here‘s the content:\n\n" +this.req.responseText}; }

 

ajax重构XMLHttpRequest,布布扣,bubuko.com

ajax重构XMLHttpRequest

标签:style   blog   http   color   os   cti   

原文地址:http://www.cnblogs.com/shaohz2014/p/3832340.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!