日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

關于異步請求ajax原理以及原生Ajax、$.ajax的基本使用詳解

瀏覽:33日期:2022-06-14 13:58:53
目錄ajax原理介紹什么是ajaxajax的優(yōu)點ajax的應用場景ajax原理分析使用ajax原生ajaxjquery使用ajax$.ajax()$.get()$.post()總結ajax原理介紹什么是ajax

ajax是Asynchronous Javascript And XML的簡寫,意思就是異步的javascript和xml,也就是異步請求。現在主要用于前后端進行交互,從而實現動態(tài)網頁,異步更新。

ajax的優(yōu)點

在傳統(tǒng)的html中,當我們向服務器發(fā)送數據后,頁面會發(fā)生跳轉,如果我們使用ajax,那么就可以在不發(fā)生跳轉的情況下實現前后端的交互,從而實現數據的更新,進而實現局部頁面更新。

ajax的應用場景

我們直接看一個最典型的案例,這就用到了ajax技術。

上面是一個搜索框,我們進行搜索的時候,下面就自動進行提示,這就是ajax的典型應用案例,我們只要輸入字符,那么就會發(fā)送ajax請求,服務器返回數據,頁面再進行展示。

ajax的應用場景很多,可以說,現在和后端通信,基本都是使用ajax來進行了。

ajax原理分析我們自己定義觸發(fā)事件,在觸發(fā)事件里面編寫ajax代碼當事件觸發(fā)時,游覽器將會發(fā)送ajax異步請求,本質還是http請求服務器返回數據,我們通過回調函數來對返回數據進行處理將數據展示到頁面上,實現局部更新

使用ajax

我們這里介紹原生的ajax和jquery使用ajax,現在還有十分流行的axious,這個的原理也是ajax,我們把ajax好,學習其他異步請求也就輕松了。

原生ajax

我們使用原生的ajax,首先要創(chuàng)建XMLHttpRequest 對象,這個對象就可以用來實現異步請求。

var xhr = new XMLHttpRequest();

我們創(chuàng)建對象后就可以使用該對象的方法,我們使用open方法,這個方法可以指定請求的方法,請求的地址,參數,以及是同步還是異步請求。open(method,url,async)

xhr.open('GET','//localhost:8080/ajax/userServlet?username=jack',true)

上面的代碼表示我們使用get方式請求,請求的地址是http//localhost:8080/ajax/userServlet,參數為username,值為jack,最后一個參數true表示使用異步請求,如果填false,那么就是同步請求。

xhr.onreadystatechange = function(){};

onreadystatechange,這個就是用來指定回調函數的,也就是當請求成功后,我們要做的事情。

ajax請求有好幾個狀態(tài),readyState,readyState保存在XMLHttpRequest中,不同的值表示不同狀態(tài)。

0: 請求未初始化1: 服務器連接已建立2: 請求已接收3: 請求處理中4: 請求已完成,且響應已就緒

我們在一般情況下,都是對readyState=4來進行操作

除了readyState,我們都知道,在http響應中有一個狀態(tài)碼,其中200表示成功,在ajax中也是一樣,XMLHttpRequest對象中有一個屬性為status,這個就是響應的狀態(tài)碼。所以,我們在進行編寫回調函數的時候就可以寫成下面那樣。

xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200){//代碼段 } }

我們在大多數情況下都是寫成上面那樣。

對于服務器返回的數據,我們使用XMLHttpRequest的responseText就可以進行接收(不能是xml),接收到值后進行處理。

var text = xhr.responseText;

我們把上面的代碼都寫好后,最后一步就是發(fā)送ajax請求,這個很簡單,直接使用send方法即可。

xhr.send();

完整的一個原生ajax請求代碼如下:

<script>window.onload = function () { //給按鈕添加點擊事件 document.getElementById('btn1').onclick = function () {//創(chuàng)建一個XMLHttpRequest對象var xhr = new XMLHttpRequest()//請求的方式,url,異步請求xhr.open('GET', '/ajax/userServlet?username=jack', true)xhr.onreadystatechange = function () { //當請求已完成,且響應已就緒并且狀態(tài)碼為200的時候我們認為正常響應了 if (xhr.readyState === 4 && xhr.status === 200) {//得到響應的數據var text = xhr.responseText; }}xhr.send(); }} </script>jquery使用ajax

上面使用原生ajax還是比較麻煩的,現在我們就使用jquery的ajax請求方式。

$.ajax()

這個方法是jquery編寫ajax的寫法,里面?zhèn)魅胍粋€對象,對象中以key:value來填寫參數$.ajax({name:value, name:value, ... }),常見的參數如下:

type:規(guī)定請求的類型(GET 或 POST)。url:規(guī)定發(fā)送請求的 URL。默認是當前頁面。data:規(guī)定要發(fā)送到服務器的數據。dataType:預期的服務器響應的數據類型。beforeSend(xhr):表示發(fā)送請求前運行的函數。success(result,status,xhr):當請求成功時運行的函數。一般只使用第一個參數,第一個參數表示響應的數據error(xhr,status,error):如果請求失敗要運行的函數。complete(xhr,status):請求完成時運行的函數(在請求成功或失敗之后均調用,即在 success 和 error 函數之后)。

上面是一些常見的屬性,詳細信息請參考jquery ajax,下面給出一個$.ajax()的使用。

//綁定點擊事件$('#btn1').click(function () { $.ajax({url: 'http://localhost:8080/ajax/userServlet',//請求的網址type: 'post', //請求方式data: { //請求數據 username: 'jack',},error: function () { //失敗后的回調函數 console.log('失敗~')},success: function (data) {//成功后的回調函數 console.log('成功:' + data);},dataType: 'json' //響應的類型 })})$.get()

上面的$.ajax()還是有些復雜,我們?yōu)榱撕喕梢灾苯邮褂?.get(),這個方法只有4個參數,寫法為 $.get(URL,data,function(data,status,xhr),dataType),我們只需要按照順序寫就行了,4個參數分別表示請求地址,請求數據,成功后的回調函數,響應類型。

其中,url是必須要寫的,其他都是可選項。請求方法為get,下面給出一個$.get()的寫法。

$.get('http://localhost:8080/ajax/userServlet', {username: 'jack' }, function (data) {console.log('請求成功 '+ data) }, 'json')

這種寫法功能和上面一樣,但是簡潔了很多。

$.post()

這個方法和$.get()基本是一樣的,就是請求的方法不一樣,其他都一樣,直接按照$.get()使用即可。

總結

我們在這篇文章中介紹了ajax,ajax的作用,工作原理等,并且還使用原生ajax和jquery的ajax來進行編程,學完后,相信大家已經對ajax有了大致認識,當然,這篇文章只介紹了ajax的一小部分內容,也是最常用的,想要深入了解,還得要通過系統(tǒng)學習才行。

到此這篇關于關于異步請求ajax原理以及原生Ajax、$.ajax的基本使用詳解的文章就介紹到這了,更多相關ajax原理與原生ajax內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Ajax
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
在线视频观看日韩| 99日韩精品| 亚洲欧美日韩国产一区二区| 好看不卡的中文字幕| 亚洲精品黄色| 日韩精品亚洲专区| 国产精品久久久久久久久久久久久久久 | 日本欧美一区二区在线观看| 欧美日韩一区二区三区四区在线观看| 精品一区视频| 久久毛片亚洲| 福利精品在线| 丝袜亚洲另类欧美| 老色鬼精品视频在线观看播放| 91看片一区| 国产精品毛片| 亚洲激情五月| 午夜在线观看免费一区| 久久福利毛片| 日韩欧美久久| 国产精品啊v在线| 精品国产a一区二区三区v免费| 欧美视频精品全部免费观看| 美女久久精品| 成人久久一区| 亚洲综合精品四区| 青青国产精品| 97欧美在线视频| 亚洲午夜91| 蜜桃视频一区二区| 国产精品日本一区二区三区在线| 激情五月色综合国产精品| 91p九色成人| 国产乱码精品一区二区亚洲| 麻豆久久久久久久| 高清av一区二区三区| 亚洲激情偷拍| 亚洲乱亚洲高清| 天堂日韩电影| 国产精品一站二站| 国模精品一区| 最新日韩av| 国产欧美高清| 99精品在线| 日韩精品视频网站| 福利精品一区| 国产毛片久久| 国产伦理久久久久久妇女| 国产一区二区三区不卡av| 久久久成人网| 中文字幕日韩欧美精品高清在线| 国产伦乱精品| 日韩国产一区| 国产精品丝袜在线播放| 国产精品99一区二区三| 久久一区视频| 亚洲高清不卡| 日韩动漫一区| 久久九九精品| 欧美日韩亚洲一区| 亚洲黑丝一区二区| 国产欧美日韩| 国产一区日韩欧美| 国产毛片精品| 在线视频精品| 国产成人精品一区二区三区免费 | 91精品视频一区二区| 午夜av成人| 日韩不卡手机在线v区| 国产自产自拍视频在线观看| 免费看黄色91| 色偷偷偷在线视频播放| 日韩中出av| 99精品美女| 精品资源在线| 天堂俺去俺来也www久久婷婷| 色一区二区三区四区| 日韩精品午夜视频| 99日韩精品| 国产一区2区| 欧美日本久久| 蜜桃视频免费观看一区| 999精品色在线播放| 国产精品久久久久久久久免费高清| 夜夜精品视频| 99国产精品免费视频观看| 久久gogo国模啪啪裸体| 丝袜美腿高跟呻吟高潮一区| 成人日韩精品| 精品国产不卡一区二区| 青草国产精品| 蜜桃视频一区二区三区在线观看| 日韩精品网站| 国产一区2区| 亚洲精品三级| 国产精品色网| 精品一区免费| 桃色一区二区| 国产伊人久久| 国产精品午夜一区二区三区| 亚洲精品日本| 蜜臀91精品一区二区三区| 激情91久久| 今天的高清视频免费播放成人| 亚洲伊人av| 成人在线视频免费看| 国产精品视频一区视频二区| 日本天堂一区| 视频一区日韩精品| 黄色在线一区| 午夜久久一区| 午夜日韩福利| 不卡视频在线| 亚洲国产综合在线看不卡| 亚洲天堂av影院| 欧美激情视频一区二区三区免费| 日本欧美一区二区| 日韩在线网址| 日韩精品免费一区二区夜夜嗨| 中文字幕日韩高清在线| 蜜桃视频一区二区| 首页欧美精品中文字幕| 午夜亚洲福利在线老司机| 在线亚洲精品| 欧美日韩国产高清电影| 精品在线99| 国产模特精品视频久久久久| 午夜一级久久| 综合干狼人综合首页| 久久aⅴ国产紧身牛仔裤| 日本91福利区| 国产欧美日韩在线观看视频| 国产精品啊啊啊| 国产成人精品999在线观看| 久久久久久夜| 久久人人97超碰国产公开结果| 久久精品观看| 亚洲欧美视频| 日韩中文字幕一区二区高清99| 亚洲精品在线二区| 欧美片网站免费| 国产一区二区视频在线看| 国产中文欧美日韩在线| 韩国精品主播一区二区在线观看| 久久精品免费一区二区三区| 亚洲一区网站| 婷婷综合成人| 久久不卡国产精品一区二区| 国产91欧美| 久久久久久久久久久9不雅视频| 香蕉国产精品| 蜜桃久久久久久| 欧美日韩一区二区国产 | 四虎精品永久免费| 国产一级成人av| 久久精品免费看| 色吊丝一区二区| 在线综合欧美| 日本中文字幕视频一区| 久久99久久人婷婷精品综合| 国产自产自拍视频在线观看| 婷婷综合网站| 日韩成人一级| 吉吉日韩欧美| 日韩精品一级二级| 国产精品欧美三级在线观看| 中文字幕色婷婷在线视频| 1024精品一区二区三区| 久久高清国产| 欧美国产不卡| 激情婷婷久久| 午夜视频一区二区在线观看| 精品一区电影| 日韩视频久久| 国产伦理久久久久久妇女| 亚洲成a人片| 亚洲乱亚洲高清| 高清av不卡| 四虎精品永久免费| 毛片在线网站| 一区二区精彩视频| 国产一区二区三区天码| 亚洲综合日韩| 久久99青青| 丝瓜av网站精品一区二区| 精品一区二区三区中文字幕视频| 尤物在线精品| 成人午夜在线| 日韩中文av| 欧美一级精品| 国产高清视频一区二区| 欧美日韩国产免费观看| 国产精品亚洲四区在线观看 | 精品欧美日韩精品| 亚洲欧美日韩国产一区| 欧美激情福利| 首页亚洲欧美制服丝腿| 成人午夜网址| 亚洲综合色婷婷在线观看| 久久男人av资源站|