小編給大家分享一下Ajax亂碼怎么辦,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)主要從事成都網(wǎng)站建設(shè)、做網(wǎng)站、網(wǎng)頁(yè)設(shè)計(jì)、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)定海,10余年網(wǎng)站建設(shè)經(jīng)驗(yàn),價(jià)格優(yōu)惠、服務(wù)專(zhuān)業(yè),歡迎來(lái)電咨詢(xún)建站服務(wù):028-86922220
ajax的全稱(chēng)是asynchronous javascript and XML ,它是異步的js和XML。它是局部刷新,異步操作。
大家都知道ajax是單線程的,而且本身是同步的,但是單線程為什么可以異步肯定大多數(shù)人并不知道,下面由張燕妮同學(xué)給大家講解一下子(不是很官方,但是很好理解):
在講解之前我先給大家說(shuō)一下線性數(shù)據(jù)結(jié)構(gòu)吧,我們可以把單線性數(shù)據(jù)結(jié)構(gòu)當(dāng)成一條線段,線段是有頭有尾的大家總知道吧,單線程就是線段的頭部沒(méi)有前區(qū),尾部沒(méi)有后區(qū),中間的每個(gè)元素前后都各有兩個(gè)元素,少了一個(gè)元素的時(shí)候,同時(shí)會(huì)有兩個(gè)元素知道并且告訴你。而且是缺一個(gè)元素都不行。
回調(diào)函數(shù)就是把函數(shù)A當(dāng)做參數(shù)傳遞給函數(shù)B,函數(shù)B執(zhí)行這個(gè)函數(shù)A。回調(diào)函數(shù)最常見(jiàn)的用法就是我們ajax請(qǐng)求數(shù)據(jù)時(shí)用到的succes() and error()這兩個(gè)函數(shù),還有setInterval里面的第一個(gè)參數(shù),也是用了回調(diào)函數(shù)?;卣{(diào)函數(shù),回調(diào)函數(shù),回調(diào)的字面意思可不就是掉個(gè)頭回去再把那條路走一遍嘛。所以ajax在回調(diào)函數(shù)success()或者error被觸發(fā)的時(shí)候掉過(guò)頭去又走了一次,然后他就是異步的了,同時(shí)ajax是異步的,跟他類(lèi)似的還有es6的promise(異步的同步操作)。
瀏覽器的進(jìn)程是多進(jìn)程的,至于為什么就跟你為什么叫XXX是一個(gè)道理呦~
第二個(gè)問(wèn)題,當(dāng)萬(wàn)能的前端遇到ajax獲取后臺(tái)數(shù)據(jù)時(shí)亂碼是怎么回事應(yīng)該是大家很糾結(jié)的。
-或許是網(wǎng)速問(wèn)題,網(wǎng)太慢。
-或許是編碼格式不統(tǒng)一,你的后臺(tái)兄弟坑了你,哈哈哈哈
ajax原生代碼都可否記得,不如我?guī)銈冝垡槐檠?,看代碼:
//1.創(chuàng)建xmlhttpRequest對(duì)象 var xhr; try{ xhr = new XMLHttpRequest(); console.log(5555) } catch(e){ //ie瀏覽器低版本兼容 xhr = new ActiveXobject("Microsoft.XMLHTTP"); } finally{ console.log(1111) } // try{} catch{} finally{}在這里是處理異常的方法,用if{}else{}也ok //if(window.XMLHttpRequest){ // xhr = new XMLHttpRequest(); // }else{ //ie瀏覽器低版本的兼容 // xhr = new ActiveXobject("Microsoft.XMLHTTP") //} //2.建立異步連接 xhr.open("get","url/+string",true/false);//true是異步,false是同步 //xhr.open("post","url",true/false) //3.發(fā)送異步請(qǐng)求 xhr.send(null);//get xhr.send(string);//post //4.獲取返回?cái)?shù)據(jù) xhr.onreadystatechange = function (){ if((xhr.readystate)==4&&(xhr.status==200)){ var data = xhr.responseText; var data = JSON.parse(data); show(data); } } function show(data){ document.getElementById("div1").innerHTML = data; }
以上是“Ajax亂碼怎么辦”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!