主頁 > 知識庫 > ajax以及一些亂碼問題

ajax以及一些亂碼問題

熱門標(biāo)簽:信貸電銷機(jī)器人有用嗎 廣西ai語音電銷機(jī)器人哪家好 電銷機(jī)器人適用范圍 察縣地圖標(biāo)注 辦理一個(gè)400電話多少錢 如何用地圖標(biāo)注各分公司 接聽電話機(jī)器人哪有 蓄意標(biāo)記地圖標(biāo)注 莆田防封電銷卡價(jià)格
創(chuàng)建xmlhttprequest 對象。

復(fù)制代碼 代碼如下:
return window.ActiveXObject ? new window.ActiveXObject('Microsoft.XMLHTTP') : new XMLHttpRequest;

次對象一個(gè) onreadystatechange 事件。有兩個(gè)屬性readyState,status。簡單的AJAX我們將使用到這幾個(gè)東西。
以下使用到的createXMLHttp()方法就是上面這段代碼!
1:以GET方式發(fā)出一個(gè)請求的實(shí)現(xiàn);

復(fù)制代碼 代碼如下:

var get = function(url, b, callback){
var xmlhttp = createXMLHttp();
xmlhttp.onreadystatechange = function(){
if(xmlhttp.readyState == 4 xmlhttp.status == 200){
callback(xmlhttp.responseText);
}
}
if(b != undefined){
var arr=[],e;
for( e in b ){
arr.push(e + '=' + encodeURIComponent(b[e]));
//arr.push(e + '=' + b[e]);
// 經(jīng)過測試如果不使用 encodeURIComponent 編碼在IE8下無法正確傳遞中文
}
url += '?' + arr.join('');
}
xmlhttp.open('GET', url, true);
xmlhttp.send();
}

// 具體這個(gè)函數(shù)的參數(shù)設(shè)置也可以根據(jù)自己的習(xí)慣來設(shè)置

使用GET方式去發(fā)送一個(gè)請求,我們是把要傳遞的參數(shù)格式化(a=1,b=2) 以后附加到URL的后面。
服務(wù)器頁面使用獲取URL參數(shù)的方式即可獲得。(比如Php: $_GET["a"]);
值得注意的是我們在格式化參數(shù)的時(shí)候 使用到一個(gè) encodeURIComponent()方法進(jìn)行了編碼是為了不出現(xiàn)亂碼;
其實(shí)有3個(gè)方法可以完成這個(gè)工作。escape,encodeURI,encodeURIComponent,大家可以查下資料。前兩個(gè)方法對于一些特殊字符還是沒有進(jìn)行編碼。
所以使用第3個(gè)是比較好的選擇了。
如果你不使用編碼直接發(fā)送數(shù)據(jù),各個(gè)瀏覽器的表現(xiàn)可能不一樣。比如IE你在發(fā)送中文數(shù)據(jù)的時(shí)候就會出現(xiàn)亂碼(當(dāng)然出現(xiàn)亂碼的情況還很多,請接著看..)。

2:以POST方法發(fā)送一個(gè)請求的實(shí)現(xiàn)
復(fù)制代碼 代碼如下:

var ajax = function(a){
var xmlhttp = createXMLHttp();
xmlhttp.onreadystatechange = function(){
if(xmlhttp.readyState == 4 xmlhttp.status == 200 ){
a.success(xmlhttp.responseText);
} else return xmlhttp;
}
xmlhttp.open('POST', a.url, true);
// 請求為post的時(shí)候 必須設(shè)置頭信息
xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
// 序列化要發(fā)送的數(shù)據(jù)
var c = [];
for(var e in a.data){
c.push(e + '=' + encodeURIComponent(a.data[e]));
// 經(jīng)過測試 經(jīng)過URL編碼以后更能夠保證發(fā)送數(shù)據(jù)的正確性。
      //不編碼可能造成部分特殊字符不能正確發(fā)送
}
a.data = c.join('');
xmlhttp.setRequestHeader("Content-length", c.length); // 好像是可選
xmlhttp.setRequestHeader("Connection", "close"); // 好像是可選
xmlhttp.send(a.data);
// 次數(shù)據(jù)發(fā)送以后服務(wù)端 使用 post 獲取數(shù)據(jù) 比如php $_POST['a'];
}

參數(shù)a是一個(gè)對象 他包含 {url:"http:...",data:{a:1,b2},success:function(){}}
             地址 數(shù)據(jù) 成功回調(diào)函數(shù)  
使用POST方法發(fā)出請求。數(shù)據(jù)也必須格式化(a=1,b=2) ;不過跟GET方法不一樣的地方是 我們是把數(shù)據(jù)寫在了send()方法里(xmlhttp.send(a.data);)。
服務(wù)器頁面使用獲取表單數(shù)據(jù)的方式即可獲得。(比如Php: $_POST["a"]);
值得注意的是在使用post發(fā)送請求的時(shí)候 我們必須設(shè)置請求的頭信息。
xmlhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
經(jīng)過測試如果不設(shè)置Content-type為application/x-www-form-urlencoded;服務(wù)器頁面是無法獲取到通過send()方法發(fā)送的數(shù)據(jù)。

最后 關(guān)于亂碼的問題。上面已經(jīng)有兩個(gè)地方會出現(xiàn)錯(cuò)誤了。
1:比如參數(shù)沒有進(jìn)行編碼直接傳遞,會出現(xiàn)傳遞不成功的問題。
2:在使用POST方法的時(shí)候沒有設(shè)置Content-type,服務(wù)器頁面無法獲取發(fā)送過來的參數(shù);
3:發(fā)送請求頁面與請求頁面的編碼問題。在標(biāo)準(zhǔn)瀏覽器下請一定保持請求頁面和被請求頁面的編碼方式是utf-8,不然中文會很悲劇。
復(fù)制代碼 代碼如下:

!--meta http-equiv="Content-Type" content="text/html; charset=gb2312" />-->
!--// 經(jīng)過測試 不使用上面的meta 申明charset在IE下會出現(xiàn)亂碼-->
!--
* header("Content-Type: text/html; charset=gb2312");
被調(diào)用的AJAX頁面使用了gb2312的編碼 在chorme下出現(xiàn)了亂碼。
在IE下正常訪問
-->


上面這里出現(xiàn)亂碼的情況非常亂,不好排除。所以保持兩個(gè)頁面編碼為UTF-8 參數(shù)編碼后在傳遞??梢杂行Х乐箒y碼
我測試的幾個(gè)文件打包 http://xiazai.jb51.net/201008/yuanma/ajax_php.rar
您可能感興趣的文章:
  • 解決ajax+php中文亂碼的方法詳解
  • JQuery AJAX 中文亂碼問題解決
  • ajax中文亂碼問題解決方案
  • ajax中文亂碼的各種解決辦法總結(jié)
  • AJAX中文亂碼PHP中完美解決方法
  • 用js來解決ajax讀取頁面亂碼
  • JQuery AJAX提交中文亂碼的解決方案
  • Javascript和Ajax中文亂碼吐血版解決方案
  • ajax 亂碼的一種解決方法
  • 淺析AJAX亂碼及錯(cuò)誤解決方案

標(biāo)簽:儋州 張掖 鷹潭 銅陵 延邊 阿拉善盟 益陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《ajax以及一些亂碼問題》,本文關(guān)鍵詞  ajax,以及,一些,亂碼,問題,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《ajax以及一些亂碼問題》相關(guān)的同類信息!
  • 本頁收集關(guān)于ajax以及一些亂碼問題的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章