电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

關(guān)于異步請(qǐng)求ajax原理以及原生Ajax、$.ajax的基本使用詳解

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

ajax是Asynchronous Javascript And XML的簡(jiǎn)寫(xiě),意思就是異步的javascript和xml,也就是異步請(qǐng)求。現(xiàn)在主要用于前后端進(jìn)行交互,從而實(shí)現(xiàn)動(dòng)態(tài)網(wǎng)頁(yè),異步更新。

ajax的優(yōu)點(diǎn)

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

ajax的應(yīng)用場(chǎng)景

我們直接看一個(gè)最典型的案例,這就用到了ajax技術(shù)。

上面是一個(gè)搜索框,我們進(jìn)行搜索的時(shí)候,下面就自動(dòng)進(jìn)行提示,這就是ajax的典型應(yīng)用案例,我們只要輸入字符,那么就會(huì)發(fā)送ajax請(qǐng)求,服務(wù)器返回?cái)?shù)據(jù),頁(yè)面再進(jìn)行展示。

ajax的應(yīng)用場(chǎng)景很多,可以說(shuō),現(xiàn)在和后端通信,基本都是使用ajax來(lái)進(jìn)行了。

ajax原理分析我們自己定義觸發(fā)事件,在觸發(fā)事件里面編寫(xiě)ajax代碼當(dāng)事件觸發(fā)時(shí),游覽器將會(huì)發(fā)送ajax異步請(qǐng)求,本質(zhì)還是http請(qǐng)求服務(wù)器返回?cái)?shù)據(jù),我們通過(guò)回調(diào)函數(shù)來(lái)對(duì)返回?cái)?shù)據(jù)進(jìn)行處理將數(shù)據(jù)展示到頁(yè)面上,實(shí)現(xiàn)局部更新

使用ajax

我們這里介紹原生的ajax和jquery使用ajax,現(xiàn)在還有十分流行的axious,這個(gè)的原理也是ajax,我們把a(bǔ)jax好,學(xué)習(xí)其他異步請(qǐng)求也就輕松了。

原生ajax

我們使用原生的ajax,首先要?jiǎng)?chuàng)建XMLHttpRequest 對(duì)象,這個(gè)對(duì)象就可以用來(lái)實(shí)現(xiàn)異步請(qǐng)求。

var xhr = new XMLHttpRequest();

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

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

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

xhr.onreadystatechange = function(){};

onreadystatechange,這個(gè)就是用來(lái)指定回調(diào)函數(shù)的,也就是當(dāng)請(qǐng)求成功后,我們要做的事情。

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

0: 請(qǐng)求未初始化1: 服務(wù)器連接已建立2: 請(qǐng)求已接收3: 請(qǐng)求處理中4: 請(qǐng)求已完成,且響應(yīng)已就緒

我們?cè)谝话闱闆r下,都是對(duì)readyState=4來(lái)進(jìn)行操作

除了readyState,我們都知道,在http響應(yīng)中有一個(gè)狀態(tài)碼,其中200表示成功,在ajax中也是一樣,XMLHttpRequest對(duì)象中有一個(gè)屬性為status,這個(gè)就是響應(yīng)的狀態(tài)碼。所以,我們?cè)谶M(jìn)行編寫(xiě)回調(diào)函數(shù)的時(shí)候就可以寫(xiě)成下面那樣。

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

我們?cè)诖蠖鄶?shù)情況下都是寫(xiě)成上面那樣。

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

var text = xhr.responseText;

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

xhr.send();

完整的一個(gè)原生ajax請(qǐng)求代碼如下:

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

上面使用原生ajax還是比較麻煩的,現(xiàn)在我們就使用jquery的ajax請(qǐng)求方式。

$.ajax()

這個(gè)方法是jquery編寫(xiě)ajax的寫(xiě)法,里面?zhèn)魅胍粋€(gè)對(duì)象,對(duì)象中以key:value來(lái)填寫(xiě)參數(shù)$.ajax({name:value, name:value, ... }),常見(jiàn)的參數(shù)如下:

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

上面是一些常見(jiàn)的屬性,詳細(xì)信息請(qǐng)參考jquery ajax,下面給出一個(gè)$.ajax()的使用。

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

上面的$.ajax()還是有些復(fù)雜,我們?yōu)榱撕?jiǎn)化,可以直接使用$.get(),這個(gè)方法只有4個(gè)參數(shù),寫(xiě)法為 $.get(URL,data,function(data,status,xhr),dataType),我們只需要按照順序?qū)懢托辛耍?個(gè)參數(shù)分別表示請(qǐng)求地址,請(qǐng)求數(shù)據(jù),成功后的回調(diào)函數(shù),響應(yīng)類型。

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

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

這種寫(xiě)法功能和上面一樣,但是簡(jiǎn)潔了很多。

$.post()

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

總結(jié)

我們?cè)谶@篇文章中介紹了ajax,ajax的作用,工作原理等,并且還使用原生ajax和jquery的ajax來(lái)進(jìn)行編程,學(xué)完后,相信大家已經(jīng)對(duì)ajax有了大致認(rèn)識(shí),當(dāng)然,這篇文章只介紹了ajax的一小部分內(nèi)容,也是最常用的,想要深入了解,還得要通過(guò)系統(tǒng)學(xué)習(xí)才行。

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

標(biāo)簽: Ajax
相關(guān)文章:
主站蜘蛛池模板: 实体店商新零售|微赢|波后|波后合作|微赢集团 | 算命免费_生辰八字_免费在线算命 - 卜算子算命网 | 萃取箱-萃取槽-PVC萃取箱厂家-混合澄清槽- 杭州南方化工设备 | 滑板场地施工_极限运动场地设计_滑板公园建造_盐城天人极限运动场地建设有限公司 | 硫酸亚铁-聚合硫酸铁-除氟除磷剂-复合碳源-污水处理药剂厂家—长隆科技 | 非甲烷总烃分析仪|环控百科 | 超细|超微气流粉碎机|气流磨|气流分级机|粉体改性机|磨粉机|粉碎设备-山东埃尔派粉体科技 | 安徽合肥项目申报咨询公司_安徽合肥高新企业项目申报_安徽省科技项目申报代理 | 污水处理设备维修_污水处理工程改造_机械格栅_过滤设备_气浮设备_刮吸泥机_污泥浓缩罐_污水处理设备_污水处理工程-北京龙泉新禹科技有限公司 | 英国雷迪地下管线探测仪-雷迪RD8100管线仪-多功能数字听漏仪-北京迪瑞进创科技有限公司 | 干粉砂浆设备_干混砂浆生产线_腻子粉加工设备_石膏抹灰砂浆生产成套设备厂家_干粉混合设备_砂子烘干机--郑州铭将机械设备有限公司 | 不锈钢/气体/液体玻璃转子流量计(防腐,选型,规格)-常州天晟热工仪表有限公司【官网】 | 膏方加工_丸剂贴牌_膏滋代加工_湖北康瑞生物科技有限公司 | 工控机,嵌入式主板,工业主板,arm主板,图像采集卡,poe网卡,朗锐智科 | 【灵硕展览集团】展台展会设计_展览会展台搭建_展览展示设计一站式服务公司 | 【星耀裂变】_企微SCRM_任务宝_视频号分销裂变_企业微信裂变增长_私域流量_裂变营销 | 耐火浇注料价格-高强高铝-刚玉碳化硅耐磨浇注料厂家【直销】 | 淘气堡_室内儿童乐园_户外无动力儿童游乐设备-高乐迪(北京) | WF2户外三防照明配电箱-BXD8050防爆防腐配电箱-浙江沃川防爆电气有限公司 | 深圳离婚律师咨询「在线免费」华荣深圳婚姻律师事务所专办离婚纠纷案件 | 彩超机-黑白B超机-便携兽用B超机-多普勒彩超机价格「大为彩超」厂家 | 两头忙,井下装载机,伸缩臂装载机,30装载机/铲车,50装载机/铲车厂家_价格-莱州巨浪机械有限公司 | 南京试剂|化学试剂|分析试剂|实验试剂|cas号查询-专业60年试剂销售企业 | 泉州陶瓷pc砖_园林景观砖厂家_石英砖地铺石价格 _福建暴风石英砖 | 广州展览制作|展台制作工厂|展览设计制作|展览展示制作|搭建制作公司 | 三氯异氰尿酸-二氯-三氯-二氯异氰尿酸钠-优氯净-强氯精-消毒片-济南中北_优氯净厂家 | CCE素质教育博览会 | CCE素博会 | 教育展 | 美育展 | 科教展 | 素质教育展 | 隐形纱窗|防护纱窗|金刚网防盗纱窗|韦柏纱窗|上海青木装潢制品有限公司|纱窗国标起草单位 | 成都软件开发_OA|ERP|CRM|管理系统定制开发_成都码邻蜀科技 | 龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司_龙门加工中心-数控龙门加工中心厂家价格-山东海特数控机床有限公司 | 自恢复保险丝_贴片保险丝_力特保险丝_Littelfuse_可恢复保险丝供应商-秦晋电子 | 杭州代理记账多少钱-注册公司代办-公司注销流程及费用-杭州福道财务管理咨询有限公司 | 干培两用箱-细菌恒温培养箱-菲斯福仪器 | 双吸泵,双吸泵厂家,OS双吸泵-山东博二泵业有限公司 | 校园文化空间设计-数字化|中医文化空间设计-党建|法治廉政主题文化空间施工-山东锐尚文化传播公司 | 全自动包装秤_全自动上袋机_全自动套袋机_高位码垛机_全自动包装码垛系统生产线-三维汉界机器(山东)股份有限公司 | 高精度-恒温冷水机-螺杆式冰水机-蒸发冷冷水机-北京蓝海神骏科技有限公司 | 电子巡更系统-巡检管理系统-智能巡检【金万码】 | 棕刚玉_白刚玉_铝酸钙-锐石新材料 | 固诺家居-全屋定制十大品牌_整体衣柜木门橱柜招商加盟 | 长城人品牌官网|