使用get遇到的問題:
1.問題一. 緩存:當每次訪問的url相同,客戶端直接讀取本地緩存里面的內容,即使后臺數據變化前臺也不會有變化;
解決方法:在?后面鏈接一個num=【隨機數Math.random()】或者num=【時間戳new Date().getTime()】,'1.php?username="May"'+num(這里沒有變量名,避免和后臺參數沖突)
2.問題二. 亂碼,當傳遞中文或者特殊字符的時候,前臺顯示出現亂碼
解決辦法:使用編碼encodeURI('蝸牛')
測試結果:通過使用Chrome測試,結果get的兩種問題,都已經得到了解決
使用post遇到的問題:
post方式,數據放在send()里面作為參數傳遞;
問題:當沒有設置請求頭的時候,后臺直接不對數據進行處理;前臺就無法獲得后臺返回的數據
解決方法:手動設置請求頭(xhr.setRequestHeader('content-type','application/x-www-form-urlencoded')),聲明發送的數據類型
【注】post沒有緩存問題,沒有編碼問題(因為在請求頭里面已經進行了聲明)
測試結果:通過使用Chrome測試,結果post這個沒有聲明頭部信息,問題是存在的
簡單的說:Get請求和Post請求的區別
1.使用Get請求時,參數在URL中顯示,而使用Post方式,則不會顯示出來
2.使用Get請求發送數據量小,Post請求發送數據量大
以上所述是小編給大家介紹的在Ajax中使用get和post所遇到的問題及解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!
您可能感興趣的文章:- jQuery中Ajax的get、post等方法詳解
- AJAX使用get與post模式的區別分析
- 有關Ajax中get和post的使用問題