日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

中止取消ajax请求,IE7下的bug解决

發(fā)布時間:2025/4/16 编程问答 19 豆豆
生活随笔 收集整理的這篇文章主要介紹了 中止取消ajax请求,IE7下的bug解决 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

最近做了一個基于文本框智能提示的效果,效果大致如下

當(dāng)我每輸入一個字符,通過ajax請求并返回匹配的結(jié)果。輸入第一個字符時,ajax的請求已經(jīng)開始,輸入第二字符時又一個ajax請求,這樣的話,用戶輸入十個字符就需要ajax請求十次,這里我需要一個特殊的要求,輸入第二個字符的時候把輸入第一個字符時的ajax請求中止或者取消(當(dāng)然前提是兩次輸入的時間間隔很短),后一個ajax請求開始時把之前的一個ajax請求中止或取消。

var ajaxResult = null; jQuery("#Keywords").keyup(function () { jQuery(".SmartTips").hide(); if (jQuery(this).val() != "") { jQuery("#SmartTips li").children().remove(); var url = "/Product/SearchSmartTips.aspx"; var data = { keyword: jQuery(this).val(), randNum: getDateNum() }; if (ajaxResult != null) { ajaxResult.abort(); } ajaxResult = jQuery.get(url, data, function (redata) { jQuery("#SmartTips").children().remove(); redata = eval("(" + redata + ")"); if (redata.length > 0) { jQuery(".SmartTips").show(); } for (var i = 0; i < redata.length; i++) { jQuery("#SmartTips").append("<li οnclick=\"getKeyword('" + redata[i].Keyword + "'," + redata[i].Num + "," + redata[i].Pid + ");\" >" + redata[i].Keyword + "</li>"); } jQuery("#SmartTips").append("<li style=\"text-align:right;\" οnclick=\"closeSmartTips()\">Close</li>"); jQuery("#SmartTips li").hover(function () { jQuery(this).addClass("hover"); }, function () { jQuery(this).removeClass("hover"); }); }); } });

文本框中的輸入一字符,判斷ajaxResult這個XmlHttpRequest對象是否為null,不等于null就通過ajaxResult.abort();的abort()方法來中止請求。核心代碼如下

var ajaxResult = null; if (ajaxResult != null) { ajaxResult.abort(); } ajaxResult = jQuery.get(url, data, function (redata) { });

但是,IE7下,abort()方法有個bug.不支持abort()方法,會提示 “SCRIPT445: 對象不支持此操作 ”,使用jquery 1.42或者之下的版本都有這個問題,可以把jquery中的

try { var oldAbort = xhr.abort; xhr.abort = function() { if ( xhr) { oldAbort.call( xhr ); } onreadystatechange( "abort" ); }; } catch(e) { } //把jquery文件中上面部分的代碼替換成下面的代碼 try { var oldAbort = xhr.abort; xhr.abort = function() { if ( xhr) { if (oldAbort.call === undefined) { oldAbort(); } else { oldAbort.call( xhr ); } } onreadystatechange( "abort" ); }; } catch(e) { } 具體的更多解決方式討論請進入http://forum.jquery.com/topic/object-doesn-t-support-this-property-or-method-from-jquery-1-4-1-in-ie7-only.

轉(zhuǎn)載于:https://www.cnblogs.com/yangbingqi/archive/2012/02/17/2355435.html

總結(jié)

以上是生活随笔為你收集整理的中止取消ajax请求,IE7下的bug解决的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。