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

1.什么是AJAX?

AJAX全稱為“Asynchronous JavaScript and XML”(異步JavaScript和XML),是一種創(chuàng)建交互式網(wǎng)頁應(yīng)用的網(wǎng)頁開發(fā)技術(shù)幅慌。它使用:
使用XHTML+CSS來標(biāo)準(zhǔn)化呈現(xiàn);
使用XML和XSLT進(jìn)行數(shù)據(jù)交換及相關(guān)操作导梆;
使用XMLHttpRequest對象與Web服務(wù)器進(jìn)行異步數(shù)據(jù)通信搀别;
使用Javascript操作Document Object Model進(jìn)行動(dòng)態(tài)顯示及交互;
使用JavaScript綁定和處理所有數(shù)據(jù)湾趾。

2.與傳統(tǒng)的web應(yīng)用比較

傳統(tǒng)的Web應(yīng)用交互由用戶觸發(fā)一個(gè)HTTP請求到服務(wù)器,服務(wù)器對其進(jìn)行處理后再返回一個(gè)新的HTHL頁到客戶端, 每當(dāng)服務(wù)器處理客戶端提交的請求時(shí),客戶都只能空閑等待,并且哪怕只是一次很小的交互绽昼、只需從服務(wù)器端得到很簡單的一個(gè)數(shù)據(jù),都要返回一個(gè)完整的HTML頁,而用戶每次都要浪費(fèi)時(shí)間和帶寬去重新讀取整個(gè)頁面唯鸭。這個(gè)做法浪費(fèi)了許多帶寬,由于每次應(yīng)用的交互都需要向服務(wù)器發(fā)送請求硅确,應(yīng)用的響應(yīng)時(shí)間就依賴于服務(wù)器的響應(yīng)時(shí)間目溉。這導(dǎo)致了用戶界面的響應(yīng)比本地應(yīng)用慢得多。
與此不同菱农,AJAX應(yīng)用可以僅向服務(wù)器發(fā)送并取回必需的數(shù)據(jù)缭付,它使用SOAP或其它一些基于XML的Web Service接口,并在客戶端采用JavaScript處理來自服務(wù)器的響應(yīng)循未。因?yàn)樵诜?wù)器和瀏覽器之間交換的數(shù)據(jù)大量減少陷猫,結(jié)果我們就能看到響應(yīng)更快的應(yīng)用。同時(shí)很多的處理工作可以在發(fā)出請求的客戶端機(jī)器上完成只厘,所以Web服務(wù)器的處理時(shí)間也減少了烙丛。

3.AJAX的工作原理

Ajax的工作原理相當(dāng)于在用戶和服務(wù)器之間加了—個(gè)中間層(AJAX引擎),使用戶操作與服務(wù)器響應(yīng)異步化舅巷。并不是所有的用戶請求都提交給服務(wù)器,像—些數(shù)據(jù)驗(yàn)證和數(shù)據(jù)處理等都交給Ajax引擎自己來做, 只有確定需要從服務(wù)器讀取新數(shù)據(jù)時(shí)再由Ajax引擎代為向服務(wù)器提交請求羔味。
Ajax其核心有JavaScript、XMLHTTPRequest钠右、DOM對象組成赋元,通過XmlHttpRequest對象來向服務(wù)器發(fā)異步請求,從服務(wù)器獲得數(shù)據(jù)飒房,然后用JavaScript來操作DOM而更新頁面搁凸。這其中最關(guān)鍵的一步就是從服務(wù)器獲得請求數(shù)據(jù)。讓我們來了解這幾個(gè)對象狠毯。

(1).XMLHTTPRequest對象

Ajax的一個(gè)最大的特點(diǎn)是無需刷新頁面便可向服務(wù)器傳輸或讀寫數(shù)據(jù)(又稱無刷新更新頁面),這一特點(diǎn)主要得益于XMLHTTP組件XMLHTTPRequest對象护糖。


2017-06-25_195349.jpg

2017-06-25_195417.jpg

4.AJAX的優(yōu)缺點(diǎn)

(1).AJAX的優(yōu)點(diǎn)

<1>.無刷新更新數(shù)據(jù)。

AJAX最大優(yōu)點(diǎn)就是能在不刷新整個(gè)頁面的前提下與服務(wù)器通信維護(hù)數(shù)據(jù)嚼松。這使得Web應(yīng)用程序更為迅捷地響應(yīng)用戶交互嫡良,并避免了在網(wǎng)絡(luò)上發(fā)送那些沒有改變的信息锰扶,減少用戶等待時(shí)間,帶來非常好的用戶體驗(yàn)寝受。

<2>.異步與服務(wù)器通信坷牛。

AJAX使用異步方式與服務(wù)器通信,不需要打斷用戶的操作很澄,具有更加迅速的響應(yīng)能力京闰。優(yōu)化了Browser和Server之間的溝通,減少不必要的數(shù)據(jù)傳輸甩苛、時(shí)間及降低網(wǎng)絡(luò)上數(shù)據(jù)流量蹂楣。

<3>.前端和后端負(fù)載平衡。

AJAX可以把以前一些服務(wù)器負(fù)擔(dān)的工作轉(zhuǎn)嫁到客戶端讯蒲,利用客戶端閑置的能力來處理捐迫,減輕服務(wù)器和帶寬的負(fù)擔(dān),節(jié)約空間和寬帶租用成本爱葵。并且減輕服務(wù)器的負(fù)擔(dān)施戴,AJAX的原則是“按需取數(shù)據(jù)”,可以最大程度的減少冗余請求和響應(yīng)對服務(wù)器造成的負(fù)擔(dān)萌丈,提升站點(diǎn)性能赞哗。

<4>.基于標(biāo)準(zhǔn)被廣泛支持。

AJAX基于標(biāo)準(zhǔn)化的并被廣泛支持的技術(shù)辆雾,不需要下載瀏覽器插件或者小程序肪笋,但需要客戶允許JavaScript在瀏覽器上執(zhí)行。隨著Ajax的成熟度迂,一些簡化Ajax使用方法的程序庫也相繼問世藤乙。同樣,也出現(xiàn)了另一種輔助程序設(shè)計(jì)的技術(shù)惭墓,為那些不支持JavaScript的用戶提供替代功能坛梁。

<5>.界面與應(yīng)用分離。

Ajax使WEB中的界面與應(yīng)用分離(也可以說是數(shù)據(jù)與呈現(xiàn)分離)腊凶,有利于分工合作划咐、減少非技術(shù)人員對頁面的修改造成的WEB應(yīng)用程序錯(cuò)誤、提高效率钧萍、也更加適用于現(xiàn)在的發(fā)布系統(tǒng)褐缠。

(2).AJAX的缺點(diǎn)

<1>.AJAX干掉了Back和History功能,即對瀏覽器機(jī)制的破壞风瘦。

在動(dòng)態(tài)更新頁面的情況下队魏,用戶無法回到前一個(gè)頁面狀態(tài),因?yàn)闉g覽器僅能記憶歷史記錄中的靜態(tài)頁面万搔。一個(gè)被完整讀入的頁面與一個(gè)已經(jīng)被動(dòng)態(tài)修改過的頁面之間的差別非常微妙胡桨;用戶通常會(huì)希望單擊后退按鈕能夠取消他們的前一次操作俐载,但是在Ajax應(yīng)用程序中,這將無法實(shí)現(xiàn)登失。
后退按鈕是一個(gè)標(biāo)準(zhǔn)的web站點(diǎn)的重要功能遏佣,但是它沒法和js進(jìn)行很好的合作。這是Ajax所帶來的一個(gè)比較嚴(yán)重的問題揽浙,因?yàn)橛脩敉窍M軌蛲ㄟ^后退來取消前一次操作的状婶。那么對于這個(gè)問題有沒有辦法?答案是肯定的馅巷,用過Gmail的知道膛虫,Gmail下面采用的Ajax技術(shù)解決了這個(gè)問題,在Gmail下面是可以后退的钓猬,但是稍刀,它也并不能改變Ajax的機(jī)制,它只是采用的一個(gè)比較笨但是有效的辦法敞曹,即用戶單擊后退按鈕訪問歷史記錄時(shí)账月,通過創(chuàng)建或使用一個(gè)隱藏的IFRAME來重現(xiàn)頁面上的變更。(例如澳迫,當(dāng)用戶在Google Maps中單擊后退時(shí)局齿,它在一個(gè)隱藏的IFRAME中進(jìn)行搜索,然后將搜索結(jié)果反映到Ajax元素上橄登,以便將應(yīng)用程序狀態(tài)恢復(fù)到當(dāng)時(shí)的狀態(tài)抓歼。)
但是,雖然說這個(gè)問題是可以解決的拢锹,但是它所帶來的開發(fā)成本是非常高的谣妻,并與Ajax框架所要求的快速開發(fā)是相背離的。這是Ajax所帶來的一個(gè)非常嚴(yán)重的問題卒稳。
一個(gè)相關(guān)的觀點(diǎn)認(rèn)為蹋半,使用動(dòng)態(tài)頁面更新使得用戶難于將某個(gè)特定的狀態(tài)保存到收藏夾中。該問題的解決方案也已出現(xiàn)展哭,大部分都使用URL片斷標(biāo)識符(通常被稱為錨點(diǎn)湃窍,即URL中#后面的部分)來保持跟蹤闻蛀,允許用戶回到指定的某個(gè)應(yīng)用程序狀態(tài)匪傍。(許多瀏覽器允許JavaScript動(dòng)態(tài)更新錨點(diǎn),這使得Ajax應(yīng)用程序能夠在更新顯示內(nèi)容的同時(shí)更新錨點(diǎn)觉痛。)這些解決方案也同時(shí)解決了許多關(guān)于不支持后退按鈕的爭論役衡。

<2>.AJAX的安全問題。

AJAX技術(shù)給用戶帶來很好的用戶體驗(yàn)的同時(shí)也對IT企業(yè)帶來了新的安全威脅薪棒,Ajax技術(shù)就如同對企業(yè)數(shù)據(jù)建立了一個(gè)直接通道手蝎。這使得開發(fā)者在不經(jīng)意間會(huì)暴露比以前更多的數(shù)據(jù)和服務(wù)器邏輯榕莺。Ajax的邏輯可以對客戶端的安全掃描技術(shù)隱藏起來,允許黑客從遠(yuǎn)端服務(wù)器上建立新的攻擊棵介。還有Ajax也難以避免一些已知的安全弱點(diǎn)钉鸯,諸如跨站點(diǎn)腳步攻擊、SQL注入攻擊和基于Credentials的安全漏洞等等邮辽。

<3>.對搜索引擎支持較弱唠雕。

對搜索引擎的支持比較弱。如果使用不當(dāng)吨述,AJAX會(huì)增大網(wǎng)絡(luò)數(shù)據(jù)的流量岩睁,從而降低整個(gè)系統(tǒng)的性能。

<4>.破壞程序的異常處理機(jī)制揣云。

至少從目前看來捕儒,像Ajax.dll,Ajaxpro.dll這些Ajax框架是會(huì)破壞程序的異常機(jī)制的邓夕。關(guān)于這個(gè)問題刘莹,曾在開發(fā)過程中遇到過,但是查了一下網(wǎng)上幾乎沒有相關(guān)的介紹焚刚。后來做了一次試驗(yàn)栋猖,分別采用Ajax和傳統(tǒng)的form提交的模式來刪除一條數(shù)據(jù)……給我們的調(diào)試帶來了很大的困難。

<5>.違背URL和資源定位的初衷汪榔。

例如蒲拉,我給你一個(gè)URL地址,如果采用了Ajax技術(shù)痴腌,也許你在該URL地址下面看到的和我在這個(gè)URL地址下看到的內(nèi)容是不同的雌团。這個(gè)和資源定位的初衷是相背離的。

<6>.AJAX不能很好支持移動(dòng)設(shè)備士聪。

一些手持設(shè)備(如手機(jī)锦援、PDA等)現(xiàn)在還不能很好的支持Ajax,比如說我們在手機(jī)的瀏覽器上打開采用Ajax技術(shù)的網(wǎng)站時(shí)剥悟,它目前是不支持的灵寺。

<7>.客戶端過肥,太多客戶端代碼造成開發(fā)上的成本区岗。

編寫復(fù)雜略板、容易出錯(cuò) ;冗余代碼比較多(層層包含js文件是AJAX的通病慈缔,再加上以往的很多服務(wù)端代碼現(xiàn)在放到了客戶端)叮称;破壞了Web的原有標(biāo)準(zhǔn)。

5.AJAX注意點(diǎn)及適用和不適用場景

(1).注意點(diǎn)
Ajax開發(fā)時(shí),網(wǎng)絡(luò)延遲——即用戶發(fā)出請求到服務(wù)器發(fā)出響應(yīng)之間的間隔——需要慎重考慮瓤檐。不給予用戶明確的回應(yīng)赂韵,沒有恰當(dāng)?shù)念A(yù)讀數(shù)據(jù),或者對XMLHttpRequest的不恰當(dāng)處理挠蛉,都會(huì)使用戶感到延遲祭示,這是用戶不希望看到的,也是他們無法理解的谴古。通常的解決方案是绍移,使用一個(gè)可視化的組件來告訴用戶系統(tǒng)正在進(jìn)行后臺操作并且正在讀取數(shù)據(jù)和內(nèi)容。
(2).Ajax適用場景
<1>.表單驅(qū)動(dòng)的交互
<2>.深層次的樹的導(dǎo)航
<3>.快速的用戶與用戶間的交流響應(yīng)
<4>.類似投票讥电、yes/no等無關(guān)痛癢的場景
<5>.對數(shù)據(jù)進(jìn)行過濾和操縱相關(guān)數(shù)據(jù)的場景
<6>.普通的文本輸入提示和自動(dòng)完成的場景
(3).Ajax不適用場景
<1>.部分簡單的表單
<2>.搜索
<3>.基本的導(dǎo)航
<4>.替換大量的文本
<5>.對呈現(xiàn)的操縱

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末蹂窖,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子恩敌,更是在濱河造成了極大的恐慌瞬测,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件纠炮,死亡現(xiàn)場離奇詭異月趟,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)恢口,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進(jìn)店門孝宗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人耕肩,你說我怎么就攤上這事因妇。” “怎么了猿诸?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵婚被,是天一觀的道長。 經(jīng)常有香客問我梳虽,道長址芯,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任窜觉,我火速辦了婚禮谷炸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘禀挫。我一直安慰自己旬陡,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布特咆。 她就那樣靜靜地躺著季惩,像睡著了一般录粱。 火紅的嫁衣襯著肌膚如雪腻格。 梳的紋絲不亂的頭發(fā)上画拾,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天,我揣著相機(jī)與錄音菜职,去河邊找鬼青抛。 笑死,一個(gè)胖子當(dāng)著我的面吹牛酬核,可吹牛的內(nèi)容都是我干的蜜另。 我是一名探鬼主播,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼嫡意,長吁一口氣:“原來是場噩夢啊……” “哼举瑰!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蔬螟,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤此迅,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后旧巾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體耸序,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年鲁猩,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了坎怪。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,100評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡廓握,死狀恐怖搅窿,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情隙券,我是刑警寧澤戈钢,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站是尔,受9級特大地震影響殉了,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜拟枚,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一薪铜、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧恩溅,春花似錦隔箍、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽滨达。三九已至,卻和暖如春俯艰,著一層夾襖步出監(jiān)牢的瞬間捡遍,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工竹握, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留画株,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓啦辐,卻偏偏與公主長得像谓传,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子芹关,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,834評論 2 345

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