校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 關于IE下AJAX的問題探討

關于IE下AJAX的問題探討

熱門標簽:外呼系統獲取客戶手機號 襄陽外呼系統接口 老虎郵局地圖標注點 徐州電銷卡外呼系統供應商 科智聯智能電銷機器人 目標三維地圖標注 百靈鳥 上海浦東百度地圖標注中心注冊 青海醫療智能外呼系統怎么樣
今天JS練手的時候,想封裝一個發送AJAX請求的對象,當然,是想要兼容全瀏覽器的。代碼如下:
復制代碼 代碼如下:

var Ajax = {
xhr: null,
callback: null,
XMLHttp: function() {
var xmlhttp;
//標準瀏覽器
if(window.XMLHttpRequest) {
try {
xmlhttp = new XMLHttpRequest();
}
catch(e) {
alert('Unknown Ajax Error');
//console.log('Unknown Ajax Error');
}
}
//IE瀏覽器
else {
if(window.ActiveXObject) {
try {
xmlhttp = new ActiveXObject('Microsoft.XMLHTTP');
}
catch(e) {
try {
xmlhttp = new ActiveXObject('MSXML2.XMLHTTP');
}
catch(e) {
alert('Unknown Ajax Error');
//console.log('Unknown Ajax Error');
}
}
}
}
return xmlhttp;
},
connect: function(paramsObj) {
var PO = paramsObj;
//判斷傳參合法性
if(!(PO instanceof Object)) {
alert('Ajax params illegal');
//console.log('Ajax params illegal');
return false;
}
else if(!(PO.urlPO.methodPO.callback)) {
return false;
}
//初始化內部參數
this.xhr = this.XMLHttp();
this.callback = PO.callback;
//遍歷params對象并生成url參數
var requestParams = '';
if(PO.params) {
for(key in Po.params) {
requestParams += '' + key + '=' + params[key];
}
requestParams = requestParams.substr(1);
}
//發起Ajax請求
try {
var xhr = this.xhr;
xhr.onreadystatechange = this.response;
//POST請求處理
if(PO.method.toLowerCase()=='post') {
xhr.open('POST',PO.url,true);
xhr.send(requestParams);
}
//GET請求處理
else if(PO.method.toLowerCase()=='get') {
xhr.open('GET',PO.url+'?'+requestParams,true);
xhr.send(null);
}
}
catch(e) {
this.callback(null,-1);
}
},
response: function() {
// 此段代碼在全瀏覽器下測試通過
// if(Ajax.xhr.readyState==4) {
// if(Ajax.xhr.status=='200') {
// Ajax.callback(Ajax.xhr.responseText);
// }
// else {
// Ajax.callback(null,Ajax.xhr.status);
// }
// }
//
// 下面的代碼在IE下失效(無報錯,請求有相應,卻沒有返回結果),其它瀏覽器無此問題
if(this.readyState==4) {
if(this.status=='200') {
Ajax.callback(this.responseText);
}
else {
Ajax.callback(null,this.status);
}
}
}
};

//Ajax實例
Ajax.connect({
url: 'test.html',
method: 'GET',
callback: function(data,err) {
if(data!=null) {
alert(data);
// console.log(data);
}
else {
alert(err);
// console.log(err);
}
}
});

問題描述: 大家看一下我代碼中有一塊注釋掉的代碼,那塊代碼是在全瀏覽器下測試通過的。而沒有注釋掉的代碼是有問題的代碼,具體表現:

在Chrome,Firefox,Opera,Safari下測試通過,在IE6、7(IE8+沒有測試)下的表現是:沒有報錯,也沒有返回結果。

對比上下兩塊代碼的不同,我想有兩個可能,一個是this指向的問題,一個是IE下onreadystatechange函數執行的上下文環境有區別于其它瀏覽器。但是現在又無法確定問題,IE6、7下的JS調試又挺困難的(試了firebug-lite,但是沒有想象中的好用,而且這個Ajax對象在firebug-lite下調用卻成功了,有點糊涂)
解決過程:

其實測試方法很簡單。主要是頭腦一發熱沒想到,吃了個飯回來就恍然大悟。

其實JS在處理this指向不明的問題的時候,可以嘗試使用this instanceof Object這類判斷去了解它指向的是一個什么類型的變量。而對于判斷是否為全局調用,則可以使用this===window。在這里我用的就是這個方法。

在代碼出現問題的那一塊,我們可以試著插入一段:

alert(this instanceof Object);

結果發現,在IE6下,返回為false!一目了然!在IE下才可能出現如此詭異的返回值!證明什么?也就是說函數的執行上下文并非是對象!如此一來,在IE下就只能想到window對象了,要知道IE向來都是奇葩。你們標準瀏覽器說window對象是對象,我就偏不認。你還在懷疑我的看法?那何不試試?

alert(this===window);

結果是true!怎么樣?沒話說了吧?所以這樣,問題就明朗了:

在IE下,AJAX請求得到響應后,回調函數onreadystatechange是在全局環境下被調用的。而在標準瀏覽器下,其執行上下文是XMLHttpRequest對象。故造成了我這次的“事故”。

標簽:荊州 紅河 商洛 股票 揭陽 佛山 辛集 咸寧

巨人網絡通訊聲明:本文標題《關于IE下AJAX的問題探討》,本文關鍵詞  關于,下,AJAX,的,問題,探討,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《關于IE下AJAX的問題探討》相關的同類信息!
  • 本頁收集關于關于IE下AJAX的問題探討的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 台东市| 墨竹工卡县| 根河市| 西昌市| 邵武市| 吉隆县| 体育| 沂南县| 乃东县| 积石山| 南充市| 开原市| 光山县| 张家口市| 宁城县| 遂昌县| 安塞县| 外汇| 邮箱| 达州市| 尼勒克县| 郓城县| 景德镇市| 湖州市| 乌什县| 锦屏县| 临沭县| 邛崃市| 苏尼特右旗| 水富县| 阜城县| 双辽市| 襄垣县| 兰州市| 梅州市| 竹北市| 木兰县| 庆云县| 松阳县| 大港区| 漳浦县|