前后端數(shù)據(jù)交互之Ajax原理及使用方法

學(xué)習(xí)前端到一個(gè)階段镊讼,必定會(huì)碰到一個(gè)不可避免的問(wèn)題排宰,即前端跟后端之間到底是怎么進(jìn)行數(shù)據(jù)交互的?那么針對(duì)這個(gè)問(wèn)題,我們來(lái)討論一下以下三種方法:
1宴树、form表單
2策菜、ajax
3、websocket(不討論)

首先酒贬,最原始的,通過(guò)form表單以post/get方式提交數(shù)據(jù)翠霍。

當(dāng)你點(diǎn)擊submit按鈕時(shí)锭吨,瀏覽器會(huì)默認(rèn)把你在input里面輸入的數(shù)據(jù),以postget的方式提交到form表單中的action這個(gè)地址寒匙。相當(dāng)于你提交表單時(shí)零如,就會(huì)向服務(wù)器發(fā)送一個(gè)請(qǐng)求,然后服務(wù)器會(huì)接受并處理提交過(guò)來(lái)的form表單锄弱,最后返回一個(gè)新的網(wǎng)頁(yè)考蕾。你可以結(jié)合以下代碼來(lái)理解這段話。

<form action="/form.html" method="post/get">
    <input type="text" name="username" placeholder="username">
    <input type="password" name="password" placeholder="password">
    <input type="submit">
  </form>

【補(bǔ)充】
1会宪、get提交數(shù)據(jù):請(qǐng)求參數(shù)(一般為input里的值)拼裝成url肖卧,相當(dāng)于向服務(wù)器發(fā)url請(qǐng)求。
2掸鹅、post提交數(shù)據(jù):直接向服務(wù)器發(fā)請(qǐng)求塞帐,參數(shù)直接發(fā)給后臺(tái)。
但是巍沙,這種方法會(huì)導(dǎo)致幾個(gè)問(wèn)題:
1葵姥、在提交時(shí),頁(yè)面會(huì)發(fā)生跳轉(zhuǎn)或刷新句携,導(dǎo)致用戶體驗(yàn)不好榔幸。
2、單項(xiàng)提交,把數(shù)據(jù)提交給后臺(tái)削咆,但是不知道后臺(tái)會(huì)給出怎樣的響應(yīng)牍疏,因?yàn)樘峤缓箜?yè)面就發(fā)生跳轉(zhuǎn)了。比如:用戶登錄态辛,那么就不知道到底是注冊(cè)成功了還是失敗了麸澜。
3、浪費(fèi)寬帶奏黑。因?yàn)榍昂髢蓚€(gè)頁(yè)面中的大部分HTML代碼往往是相同的炊邦。但由于每次應(yīng)用的交互都需要向服務(wù)器發(fā)送請(qǐng)求,應(yīng)用的響應(yīng)時(shí)間就依賴于服務(wù)器的響應(yīng)時(shí)間熟史,這就導(dǎo)致了用戶界面的響應(yīng)比本地應(yīng)用慢的多馁害。

為了解決上述問(wèn)題,2005年出現(xiàn)了Ajax蹂匹。

一碘菜、什么是Ajax
1、Ajax的全稱是Asynchronous JavaScript and XML限寞,即異步JavaScript+XML忍啸。
2、它是一種技術(shù)方案履植,但并不是一種新技術(shù)计雌。
3、它依賴的是現(xiàn)有的CSS/HTML/Javascript玫霎,而其中最核心的依賴是瀏覽器提供的XMLHttpRequest對(duì)象凿滤。這個(gè)對(duì)象為向服務(wù)器發(fā)送請(qǐng)求和解析服務(wù)器響應(yīng)提供了流暢的接口,使得瀏覽器可以發(fā)出HTTP請(qǐng)求與接收HTTP響應(yīng)庶近,實(shí)現(xiàn)在頁(yè)面不刷新的情況下和服務(wù)端進(jìn)行數(shù)據(jù)交互翁脆。
【補(bǔ)充】Ajax和XMLHttpRequest 兩者的關(guān)系:我們使用XMLHttpRequest對(duì)象來(lái)發(fā)送一個(gè)Ajax請(qǐng)求。
二鼻种、怎么實(shí)現(xiàn)在頁(yè)面不刷新的情況下和服務(wù)端進(jìn)行數(shù)據(jù)交互?
1反番、XMLHttpRequest對(duì)象
2、fecth(不討論)

XMLHttpRequest對(duì)象

為了便于我們理解怎么使用XMLHttpRequest對(duì)象實(shí)現(xiàn)在頁(yè)面不刷新的情況下和服務(wù)端進(jìn)行數(shù)據(jù)交互普舆,我們先來(lái)看下下面的代碼恬口。

<script>
  var xhr = new XMLHttpRequest()  //創(chuàng)建一個(gè)對(duì)象
  xhr.open('GET','/helloAjax.json',false)  //設(shè)置ajax,.open()方法里面的三個(gè)參數(shù)分別是:要發(fā)送的請(qǐng)求類型沼侣、請(qǐng)求的url祖能、表示是否異步發(fā)送請(qǐng)求的布爾值
  xhr.send()  //發(fā)出請(qǐng)求
  var data = xhr.responseText  //當(dāng)請(qǐng)求到來(lái)時(shí),讀取請(qǐng)求中的數(shù)據(jù)
  console.log(data)  //輸出
</script>

這樣就是一個(gè)使用XMLHttpRequest對(duì)象發(fā)送的Ajax請(qǐng)求了蛾洛,現(xiàn)在我們來(lái)分析分析這段代碼养铸。
首先雁芙,XMLHttpRequest構(gòu)造函數(shù)通過(guò)new的方式構(gòu)造一個(gè)XHR對(duì)象,并將這個(gè)對(duì)象賦值給xhr(可取任意名字)
然后钞螟,調(diào)用XMLHttpRequest對(duì)象的方法opensend兔甘。

XMLHttpRequest對(duì)象的兩個(gè)重要方法

調(diào)用send方法之后請(qǐng)求被發(fā)往服務(wù)器,由于這次請(qǐng)求是同步的鳞滨,JS代碼會(huì)在xhr.send()這個(gè)步驟暫停掉洞焙,一直等到服務(wù)器根據(jù)請(qǐng)求生成響應(yīng)(Response),傳回給XHR對(duì)象拯啦,再繼續(xù)執(zhí)行澡匪。
最后,在收到響應(yīng)后相應(yīng)數(shù)據(jù)會(huì)填充到XHR對(duì)象的屬性褒链。有四個(gè)相關(guān)屬性會(huì)被填充:
1唁情、responseText——從服務(wù)器進(jìn)程作為響應(yīng)主體被返回的文本。
2甫匹、responseXML——從服務(wù)器進(jìn)程返回的DOM兼容的文檔數(shù)據(jù)對(duì)象甸鸟。
3、status——響應(yīng)的HTTP狀態(tài)兵迅。即從服務(wù)器返回的數(shù)字代碼抢韭,如404(未找到)和200(已就緒)。
4恍箭、statusText——HTTP狀態(tài)的說(shuō)明篮绰。伴隨狀態(tài)碼的字符串信息。

但多數(shù)情況下季惯,我們還是要發(fā)送異步請(qǐng)求,才能讓JavaScript繼續(xù)執(zhí)行而不必等待響應(yīng)臀突。為了更好的理解ajax發(fā)送異步請(qǐng)求勉抓,我們來(lái)看以下代碼

   <script>
        var xhr = new XMLHttpRequest()
        //請(qǐng)求響應(yīng)過(guò)程的當(dāng)前活動(dòng)階段
        xhr.onreadystatechange = function(){
            console.log('readyState:',xhr.readyState)
        }
        xhr.open('GET','hello.json',true)
        xhr.send()
        //監(jiān)聽(tīng)請(qǐng)求狀態(tài)
        xhr.onload = function(){             //onload相當(dāng)于readyState=4
            console.log(xhr.status)
            if((xhr.status >= 200 && xhr.status <= 300) || xhr.status === 304){
                console.log(xhr.responseText)
            }else{
                console.log(error)
            }
        }
    </script>

上述代碼中,XHR對(duì)象的readyState屬性候学,表示請(qǐng)求響應(yīng)過(guò)程的當(dāng)前活動(dòng)階段藕筋。該屬性可取的值如下:

  • 0:未初始化。尚未調(diào)用open()方法梳码。
  • 1:?jiǎn)?dòng)隐圾。已經(jīng)調(diào)用open()方法,但尚未調(diào)用send()方法掰茶。
  • 2:發(fā)送暇藏。已經(jīng)調(diào)用send()方法,但尚未接收到響應(yīng)濒蒋。
  • 3:接收盐碱。已經(jīng)接收到部分響應(yīng)數(shù)據(jù)把兔。
  • 4:完成。已經(jīng)接收到全部響應(yīng)數(shù)據(jù)瓮顽,而且已經(jīng)可以在客戶端使用了县好。//onload表示readyState = 4
    【注意】
    1、只要readyState屬性的值由一個(gè)值變成另一個(gè)值暖混,就會(huì)觸發(fā)一次readystatechange事件
    2缕贡、必須在調(diào)用open()方法之前指定readystatechange事件處理程序才能確保跨瀏覽器兼容性拣播。
GET請(qǐng)求/POST請(qǐng)求
  • 與 POST 相比晾咪,GET 更簡(jiǎn)單也更快,并且在大部分情況下都能用诫尽。
  • 然而禀酱,在以下情況中,請(qǐng)使用 POST 請(qǐng)求:
    1牧嫉、無(wú)法使用緩存文件(更新服務(wù)器上的文件或數(shù)據(jù)庫(kù))
    2剂跟、向服務(wù)器發(fā)送大量數(shù)據(jù)(POST 沒(méi)有數(shù)據(jù)量限制)
    3、發(fā)送包含未知字符的用戶輸入時(shí)酣藻,POST 比 GET 更穩(wěn)定也更可靠
  • GET請(qǐng)求/POST請(qǐng)求使用方法

一個(gè)簡(jiǎn)單的 GET 請(qǐng)求

xhr.open('GET','lazyLoad.html',true)
xhr.send()

如果希望通過(guò) GET 方法發(fā)送信息曹洽,可以向 URL 末尾添加字符串參數(shù)

xhr.open('GET','/login?username=Iris&password=12345',true)
xhr.send()

一個(gè)簡(jiǎn)單的 POST 請(qǐng)求

xhr.open('POST','/login',true)
xhr.send('username=Iris&password=12345')

如果向send()里面?zhèn)鬟f一個(gè)對(duì)象,可以用函數(shù)將該對(duì)象拼接成字符串形式

        xhr.open('POST','/login',true)
        xhr.send(makeUrl({             //step3辽剧、這個(gè)時(shí)候send()里面就不用發(fā)字符串了送淆,直接發(fā)傳遞的對(duì)象就好了
            username:'Iris',
            address:'ChangSha',
            age:21
        }))

        //step2、用戶傳遞的是一個(gè)對(duì)象時(shí)   (實(shí)參是用戶傳遞的這個(gè)對(duì)象)
        makeUrl({
            username:'Iris',
            address:'ChangSha',
            age:21
        })
        //step1怕轿、將拼接的過(guò)程寫成一個(gè)函數(shù)偷崩,向函數(shù)makeUrl()里面?zhèn)鬟f一個(gè)形參
        function makeUrl(obj){
            var arr = []           //遍歷這個(gè)對(duì)象
            for(var key in obj){
                arr.push(key + '=' + obj[key])
            }
            return arr.join('&')
        }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市撞羽,隨后出現(xiàn)的幾起案子阐斜,更是在濱河造成了極大的恐慌,老刑警劉巖诀紊,帶你破解...
    沈念sama閱讀 216,919評(píng)論 6 502
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件谒出,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡邻奠,警方通過(guò)查閱死者的電腦和手機(jī)笤喳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,567評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)碌宴,“玉大人杀狡,你說(shuō)我怎么就攤上這事∵蠛恚” “怎么了捣卤?”我有些...
    開(kāi)封第一講書人閱讀 163,316評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵忍抽,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我董朝,道長(zhǎng)鸠项,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,294評(píng)論 1 292
  • 正文 為了忘掉前任子姜,我火速辦了婚禮祟绊,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘哥捕。我一直安慰自己牧抽,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,318評(píng)論 6 390
  • 文/花漫 我一把揭開(kāi)白布遥赚。 她就那樣靜靜地躺著扬舒,像睡著了一般。 火紅的嫁衣襯著肌膚如雪凫佛。 梳的紋絲不亂的頭發(fā)上讲坎,一...
    開(kāi)封第一講書人閱讀 51,245評(píng)論 1 299
  • 那天,我揣著相機(jī)與錄音愧薛,去河邊找鬼晨炕。 笑死,一個(gè)胖子當(dāng)著我的面吹牛毫炉,可吹牛的內(nèi)容都是我干的瓮栗。 我是一名探鬼主播,決...
    沈念sama閱讀 40,120評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼瞄勾,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼费奸!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起进陡,我...
    開(kāi)封第一講書人閱讀 38,964評(píng)論 0 275
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤货邓,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后四濒,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,376評(píng)論 1 313
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡职辨,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,592評(píng)論 2 333
  • 正文 我和宋清朗相戀三年盗蟆,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片舒裤。...
    茶點(diǎn)故事閱讀 39,764評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡喳资,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出腾供,到底是詐尸還是另有隱情仆邓,我是刑警寧澤鲜滩,帶...
    沈念sama閱讀 35,460評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站节值,受9級(jí)特大地震影響徙硅,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜搞疗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,070評(píng)論 3 327
  • 文/蒙蒙 一嗓蘑、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧匿乃,春花似錦桩皿、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,697評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至宛徊,卻和暖如春佛嬉,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背岩调。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,846評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工巷燥, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人号枕。 一個(gè)月前我還...
    沈念sama閱讀 47,819評(píng)論 2 370
  • 正文 我出身青樓缰揪,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親葱淳。 傳聞我的和親對(duì)象是個(gè)殘疾皇子钝腺,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,665評(píng)論 2 354

推薦閱讀更多精彩內(nèi)容