首頁 >web前端 >js教程 >jquery1.8版本使用ajax實作微信呼叫出現的問題分析及解決方法

jquery1.8版本使用ajax實作微信呼叫出現的問題分析及解決方法

亚连
亚连原創
2018-05-24 14:52:282174瀏覽

這篇文章主要介紹了jquery1.8版本使用ajax實現微信調用出現的問題分析及解決辦法的相關資料,需要的朋友可以參考下

先給大家說下問題背景:最近在做一個項目,開發微信的某個功能,使用的是asp.net開發,jquery1.8.0版。

   在微信中點選按鈕觸發事件,呼叫ajax與伺服器端進行交互,回呼函數走的是error。

分析原因:首先我想到的是回傳的資料型別有問題,因為在jquery 版本在1.4以上對json的格式非常嚴格,需要符合{"target":true, "message":"成功"}這樣的格式。用JSON.stringify()函數分析了response對象,結果符合,排除了原因。

既然ajax 走的是error,我開始分析error函數的參數,分別有XMLHttpRequest, textStatus, errorThrown。我發現XMLHttpRequest.status等於0,XMLHttpRequest.readyState等於0,表示窗體中有XMLHttpRequest物件卻沒有初始化,接下來開始研究怎麼初始化XMLHttpRequest物件。

解決方法:

var xmlHttpRequest;
$(function(){
if(window.XMLHttpRequest){
xmlHttpRequest=new XMLHttpRequest();
}else{
xmlHttpRequest=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlHttpRequest.open("GET","AjaxServlet",true);
});

這樣就能解決以上描述的問題,注意PC端存取一般的Ajax不會出現問題,因為PC中瀏覽器都有內建的XMLHttpRequest對象,而在微信中,出現此現象,可能需要手動去建置和初始化。

ps:安卓版微信自帶瀏覽器和IE6瀏覽器ajax請求abort錯誤處理

給頁面元素綁定了一個click事件用來觸發ajax請求,在安卓微信自帶瀏覽器中和IE6下,請求時常會被中斷,返回錯​​誤類型“abort”,在其他瀏覽器中都一切正常。

在IE6中使用Fiddler2和httpWatch監視請求,經常會出現”aborted”,折騰特麼一個週末,。 。 。 。 。

不說廢話了....

解決方法:在標籤上加上onclick='return false;'

上面是我整理給大家的,希望未來會對大家有幫助。

相關文章:

基於h5的history改善ajax列表請求體驗

簡單談談AJAX核心物件

ajax資料傳輸方式實例詳解

以上是jquery1.8版本使用ajax實作微信呼叫出現的問題分析及解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn