亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

Ajax程序設計入門

2019-11-18 16:34:38
字體:
來源:轉載
供稿:網友

一、使用Ajax的主要原因

1、通過適當的Ajax應用達到更好的用戶體驗;

2、把以前的一些服務器負擔的工作轉嫁到客戶端,利于客戶端閑置的處理能力來處理,減輕服務器和帶寬的負擔,從而達到節約ISP的空間及帶寬租用成本的目的。

二、引用

Ajax這個概念的最早提出者Jesse James Garrett認為:Ajax是Asynchronous javaScript and xml的縮寫。Ajax并不是一門新的語言或技術,它實際上是幾項技術按一定的方式組合在一在同共的協作中發揮各自的作用,它包括:

·使用XHTML和CSS標準化呈現;

·使用DOM實現動態顯示和交互;

·使用XML和XSLT進行數據交換與處理;

·使用xmlhttpRequest進行異步數據讀取;

·最后用Javascript綁定和處理所有數據;

Ajax的工作原理相當于在用戶和服務器之間加了—個中間層,使用戶操作與服務器響應異步化。并不是所有的用戶請求都提交給服務器,像—些數據驗證和數據處理等都交給Ajax引擎自己來做,只有確定需要從服務器讀取新數據時再由Ajax引擎代為向服務器提交請求。

三、概述
 

雖然Garrent列出了7條Ajax的構成技術,但個人認為,所謂的Ajax其核心只有JavaScript、XMLHTTPRequest和DOM,如果所用數據格式為XML的話,還可以再加上XML這一項(Ajax從服務器端返回的數據可以是XML格式,也可以是文本等其他格式)。

在舊的交互方式中,由用戶觸發一個HTTP請求到服務器,服務器對其進行處理后再返回一個新的HTHL頁到客戶端,每當服務器處理客戶端提交的請求時,客戶都只能空閑等待,并且哪怕只是一次很小的交互、只需從服務器端得到很簡單的一個數據,都要返回一個完整的HTML頁,而用戶每次都要浪費時間和帶寬去重新讀取整個頁面。

而使用Ajax后用戶從感覺上幾乎所有的操作都會很快響應沒有頁面重載(白屏)的等待。

1、XMLHTTPRequest

Ajax的一個最大的特點是無需刷新頁面便可向服務器傳輸或讀寫數據(又稱無刷新更新頁面),這一特點主要得益于XMLHTTP組件XMLHTTPRequest對象。這樣就可以向再發桌面應用程序只同服務器進行數據層面的交換,而不用每次都刷新界面也不用每次將數據處理的工作提交給服務器來做,這樣即減輕了服務器的負擔又加快了響應速度、縮短了用戶等候時間。

最早應用XMLHTTP的是微軟,IE(IE5以上)通過允許開發人員在Web頁面內部使用XMLHTTP ActiveX組件擴展自身的功能,開發人員可以不用從當前的Web頁面導航而直接傳輸數據到服務器上或者從服務器取數據。這個功能是很重要的,因為它幫助減少了無狀態連接的痛苦,它還可以排除下載冗余HTML的需要,從而提高進程的速度。Mozilla(Mozilla1.0以上及NetScape7以上)做出的回應是創建它自己的繼承XML代理類:XMLHttpRequest類。Konqueror (和Safari v1.2,同樣也是基于KHTML的瀏覽器)也支持XMLHttpRequest對象,而Opera也將在其v7.6x+以后的版本中支持XMLHttpRequest對象。對于大多數情況,XMLHttpRequest對象和XMLHTTP組件很相似,方法和屬性也類似,只是有一小部分屬性不支持。

XMLHttpRequest的應用:

·XMLHttpRequest對象在JS中的應用

var xmlhttp = new XMLHttpRequest();

·微軟的XMLHTTP組件在JS中的應用

var xmlhttp = new ActiveXObject(Microsoft.XMLHTTP);

var xmlhttp = new ActiveXObject(Msxml2.XMLHTTP);

XMLHttpRequest 對象方法

/**

* Cross-browser XMLHttpRequest instantiation.

*/

if (typeof XMLHttpRequest == ’undefined’) {

 XMLHttpRequest = function () {

var msxmls = [’MSXML3’, ’MSXML2’, ’Microsoft’]

for (var i=0; i < msxmls.length; i++) {

 try {

return new ActiveXObject(msxmls[i]+’.XMLHTTP’)

 } catch (e) { }

}

throw new Error("No XML component installed!")

 }

}

function createXMLHttpRequest() {

 try {

// Attempt to create it "the Mozilla way"

if (window.XMLHttpRequest) {

 return new XMLHttpRequest();

}

// Guess not - now the IE way

if (window.ActiveXObject) {

 return new ActiveXObject(getXMLPrefix() + ".XmlHttp");

}

 }

 catch (ex) {}

 return false;

};
 
XMLHttpRequest 對象方法

方法 描述
 abort() 停止當前請求
 getAllResponseHeaders() 作為字符串返問完整的headers
 getResponseHeader("headerLabel") 作為字符串返問單個的header標簽
 open("method","URL"[,asyncFlag[,"userName"[, "passWord"]]]) 設置未決的請求的目標 URL, 方法, 和其他參數
 send(content) 發送請求
 setRequestHeader("label", "value") 設置header并和請求一起發送

XMLHttpRequest 對象屬性

 屬性 描述
 onreadystatechange 狀態改變的事件觸發器
 readyState 對象狀態(integer):

0 = 未初始化

1 = 讀取中

2 = 已讀取

3 = 交互中

4 = 完成
 responseText 服務器進程返回數據的文本版本
 responseXML 服務器進程返回數據的兼容DOM的XML文檔對象
 status 服務器返回的狀態碼, 如:404 = "文件末找到" 、200 ="成功"
 statusText 服務器返回的狀態文本信息

2、JavaScript

JavaScript是一在瀏覽器中大量使用的編程語言,,他以前一直被貶低為一門糟糕的語言(他確實在使用上比較枯燥),以在常被用來作一些用來炫耀的小玩意和惡作劇或是單調瑣碎的表單驗證。但事實是,他是一門真正的編程語言,有著自已的標準并在各種瀏覽器中被廣泛支持。

3、DOM

Document Object Model。

DOM是給 HTML 和 XML 文件使用的一組 API。它提供了文件的結構表述,讓你可以改變其中的內容及可見物。其本質是建立網頁與 Script 或程序語言溝通的橋梁。

所有WEB開發人員可操作及建立文件的屬性、方法及事件都以對象來展現(例如,document 就代表“文件本身“這個對像,table 對象則代表 HTML 的表格對象等等)。這些對象可以由當今大多數的瀏覽器以 Script 來取用。

一個用HTML或XHTML構建的網頁也可以看作是一組結構化的數據,這些數據被封在DOM(Document Object Model)中,DOM提供了網頁中各個對象的讀寫的支持。

4、XML

可擴展的標記語言(Extensible Markup Language)具有一種開放的、可擴展的、可自描述的語言結構,它已經成為網上數據和文檔傳輸的標準。它是用來描述數據結構的一種語言,就正如他的名字一樣。他使對某些結構化數據的定義更加容易,并且可以通過他和其他應用程序交換數據。
5、綜合 五、Ajax的優勢

 

Jesse James Garrett提到的Ajax引擎,實際上是一個比較復雜的JavaScript應用程序,用來處理用戶請求,讀寫服務器和更改DOM內容。

JavaScript的Ajax引擎讀取信息,并且互動地重寫DOM,這使網頁能無縫化重構,也就是在頁面已經下載完畢后改變頁面內容,這是我們一直在通過JavaScript和DOM在廣泛使用的方法,但要使網頁真正動態起來,不僅要內部的互動,還需要從外部獲取數據,在以前,我們是讓用戶來輸入數據并通過DOM來改變網頁內容的,但現在,XMLHTTPRequest,可以讓我們在不重載頁面的情況下讀寫服務器上的數據,使用戶的輸入達到最少。

基于XML的網絡通訊也并不是新事物,實際上Flash和JAVA Applet都有不錯的表現,現在這種富交互在網頁上也可用了,基于標準化的并被廣泛支持和技術,并且不需要插件或下載小程序。

Ajax是傳統WEB應用程序的一個轉變。以前是服務器每次生成HTML頁面并返回給客戶端(瀏覽器)。在大多數網站中,很多頁面中至少90%都是一樣的,比如:結構、格式、頁頭、頁尾、廣告等,所不同的只是一小部分的內容,但每次服務器都會生成所有的頁面再返回給客戶端,這無形之中是一種浪費,不管是對于用戶的時間、帶寬、CPU耗用,還是對于ISP的高價租用的帶寬和空間來說。如果按一頁來算,只能幾K或是幾十K可能并不起眼,但像SINA每天要生成幾百萬個頁面的大ISP來說,可以說是損失巨大的。而AJAX可以所為客戶端和服務器的中間層,來處理客戶端的請求,并根據需要向服務器端發送請求,用什么就取什么、用多少就取多少,就不會有數據的冗余和浪費,減少了數據下載總量,而且更新頁面時不用重載全部內容,只更新需要更新的那部分即可,相對于純后臺處理并重載的方式縮短了用戶等待時間,也把對資源的浪費降到最低,基于標準化的并被廣泛支持和技術,并且不需要插件或下載小程序,所以Ajax對于用戶和ISP來說是雙盈的。

Ajax使WEB中的界面與應用分離(也可以說是數據與呈現分離),而在以前兩者是沒有清晰的界限的,數據與呈現分離的分離,有利于分工合作、減少非技術人員對頁面的修改造成的WEB應用程序錯誤、提高效率、也更加適用于現在的發布系統。也可以把以前的一些服務器負擔的工作轉嫁到客戶端,利于客戶端閑置的處理能力來處理。

四、應用

Ajax理念的出現,揭開了無刷新更新頁面時代的序幕,并有代替傳統web開發中采用form(表單)遞交方式更新web頁面的趨勢,可以算是一個里程碑。但Ajax都不是適用于所有地方的,它的適用范圍是由它的特性所決定的。

舉個應用的例子,是關于級聯菜單方面的Ajax應用。

我們以前的對級聯菜單的處理是這樣的:

為了避免每次對菜單的操作引起的重載頁面,不采用每次調用后臺的方式,而是一次性將級聯菜單的所有數據全部讀取出來并寫入數組,然后根據用戶的操作用JavaScript來控制它的子集項目的呈現,這樣雖然解決了操作響應速度、不重載頁面以及避免向服務器頻繁發送請求的問題,但是如果用戶不對菜單進行操作或只對菜單中的一部分進行操作的話,那讀取的數據中的一部分就會成為冗余數據而浪費用戶的資源,特別是在菜單結構復雜、數據量大的情況下(比如菜單有很多級、每一級菜又有上百個項目),這種弊端就更為突出。

如果在此案中應用Ajax后,結果就會有所改觀:

在初始化頁面時我們只讀出它的第一級的所有數據并顯示,在用戶操作一級菜單其中一項時,會通過Ajax向后臺請求當前一級項目所屬的二級子菜單的所有數據,如果再繼續請求已經呈現的二級菜單中的一項時,再向后面請求所操作二級菜單項對應的所有三級菜單的所有數據,以此類推……這樣,用什么就取什么、用多少就取多少,就不會有數據的冗余和浪費,減少了數據下載總量,而且更新頁面時不用重載全部內容,只更新需要更新的那部分即可,相對于后臺處理并重載的方式縮短了用戶等待時間,也把對資源的浪費降到最低。

此外,Ajax由于可以調用外部數據,也可以實現數據聚合的功能(當然要有相應授權),比如微軟剛剛在3月15日發布的在線rss閱讀器BETA版;還可以利于一些開放的數據,開發自已的一些應用程序,比如用Amazon的數據作的一些新穎的圖書搜索應用。

總之,Ajax適用于交互較多,頻繁讀數據,數據分類良好的WEB應用。

 

1、減輕服務器的負擔。因為Ajax的根本理念是“按需取數據”,所以最大可能在減少了冗余請求和響影對服務器造成的負擔;

2、無刷新更新頁面,減少用戶實際和心理等待時間;

首先,“按需取數據”的模式減少了數據的實際讀取量,打個很形象的比方,如果說重載的方式是從一個終點回到原點再到另一個終點的話,那么Ajax就是以一個終點為基點到達另一個終點;

其次,即使要讀取比較大的數據,也不用像RELOAD一樣出現白屏的情況,由于Ajax是用XMLHTTP發送請求得到服務端應答數據,在不重新載入整個頁面的情況下用Javascript操作DOM最終更新頁面的,所以在讀取數據的過程中,用戶所面對的也不是白屏,而是原來的頁面狀態(或者可以加一個LOADING的提示框讓用戶了解數據讀取的狀態),只有當接收到全部數據后才更新相應部分的內容,而這種更新也是瞬間的,用戶幾乎感覺不到??傊脩羰呛苊舾械?,他們能感覺到你對他們的體貼,雖然不太可能立竿見影的效果,但會在用戶的心中一點一滴的積累他們對網站的依賴。

3、更好的用戶體驗;

4、也可以把以前的一些服務器負擔的工作轉嫁到客戶端,利于客戶端閑置的處理能力來處理,減輕服務器和帶寬的負擔,節約空間和帶寬租用成本;

5、Ajax由于可以調用外部數據;

6、基于標準化的并被廣泛支持和技術,并且不需要插件或下載小程序;

7、Ajax使WEB中的界面與應用分離(也可以說是數據與呈現分離);

8、對于用戶和ISP來說是雙盈的。

六、Ajax的問題

1、一些手持設備(如手機、PDA等)現在還不能很好的支持Ajax;

2、用JavaScript作的Ajax引擎,JavaScript的兼容性和DeBug都是讓人頭痛的事;

3、Ajax的無刷新重載,由于頁面的變化沒有刷新重載那么明顯,所以容易給用戶帶來困擾――用戶不太清楚現在的數據是新的還是已經更新過的;現有的解決有:在相關位置提示、數據更新的區域設計得比較明顯、數據更新后給用戶提示等;

4、對流媒體的支持沒有FLASH、Java Applet好;


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲最新av网址| 2019最新中文字幕| 中文字幕日韩精品在线| 2020欧美日韩在线视频| 欧美成人午夜免费视在线看片| 亚洲免费精彩视频| 久久人人97超碰精品888| 亚洲欧美日韩国产成人| 97在线看免费观看视频在线观看| 久久激情视频免费观看| 91国偷自产一区二区三区的观看方式| 欧美乱人伦中文字幕在线| 北条麻妃一区二区三区中文字幕| 美女国内精品自产拍在线播放| 欧美成人免费在线视频| 久久久久久久影院| 狠狠色狠色综合曰曰| 国产剧情久久久久久| 91精品国产91久久久| 日韩成人高清在线| 国产精品网站入口| 久久视频免费观看| 久久久免费在线观看| 欧美高清视频一区二区| 九九热这里只有精品免费看| 久青草国产97香蕉在线视频| 久久精品久久久久久| 性金发美女69hd大尺寸| 国产精品电影网| 国产偷国产偷亚洲清高网站| 社区色欧美激情 | 2020久久国产精品| 欧美又大又硬又粗bbbbb| 亚洲丁香婷深爱综合| 欧美日韩国产精品专区| 亚洲视频专区在线| 中文字幕综合在线| 538国产精品视频一区二区| 中文字幕日韩视频| 国产欧美久久一区二区| 欧美www视频在线观看| 国产精品美女久久久久久免费| 亚洲欧美国产日韩天堂区| 热门国产精品亚洲第一区在线| 亚洲美女福利视频网站| 国内精品久久久久伊人av| 国产精品av免费在线观看| 91精品啪在线观看麻豆免费| 亚洲精品福利免费在线观看| x99av成人免费| 亚洲精品一区av在线播放| 国产精品视频中文字幕91| www.99久久热国产日韩欧美.com| 在线观看亚洲区| 国产精品久久久久久久久久久新郎| 欧美成人激情图片网| 中文字幕久精品免费视频| 亚洲r级在线观看| 欧美一级黑人aaaaaaa做受| 久久久精品在线观看| 97免费视频在线| 狠狠躁天天躁日日躁欧美| 久久久久久久一区二区| 日韩免费黄色av| 在线看国产精品| 国产精品旅馆在线| 国产精品欧美久久久| 欧美电影在线观看完整版| 国产精品稀缺呦系列在线| 欧美裸身视频免费观看| 97久久久免费福利网址| 久久久伊人日本| 久久青草福利网站| 自拍偷拍亚洲精品| 欧美肥老太性生活视频| 色综合伊人色综合网| 欧美色videos| 亚洲天堂一区二区三区| 日韩av在线网页| 亚洲高清色综合| 亚洲午夜久久久久久久| 国外成人免费在线播放| 丝袜美腿亚洲一区二区| 久久99视频精品| 两个人的视频www国产精品| 91精品国产综合久久久久久蜜臀| 伊人久久久久久久久久久| 色综合久久中文字幕综合网小说| 久久人91精品久久久久久不卡| 国产精品视频免费在线观看| 98精品国产高清在线xxxx天堂| 亚洲高清久久网| 日本成人在线视频网址| 91在线中文字幕| 中文字幕日韩在线视频| 欧美中文在线免费| 欧美日韩美女在线观看| 欧美电影免费在线观看| 狠狠躁天天躁日日躁欧美| 精品国产一区二区三区久久久| 欧美性猛交xxxx乱大交| 久久综合亚洲社区| 久久成人这里只有精品| 欧美大片免费观看| 国产精品亚洲激情| 成人亚洲综合色就1024| 色综合久久88色综合天天看泰| 亚洲一区av在线播放| 日韩高清av在线| 亚洲理论在线a中文字幕| 久久综合久久八八| 日韩小视频在线观看| 日韩在线播放一区| 国产精品一区二区三区毛片淫片| 亚洲精品99999| 一区二区三区黄色| 精品国产区一区二区三区在线观看| 亚洲欧美中文日韩v在线观看| 日韩欧亚中文在线| 日韩中文理论片| 欧美视频中文字幕在线| 欧美日韩另类字幕中文| 久久成人亚洲精品| 麻豆一区二区在线观看| 久久精品精品电影网| 欧美专区第一页| 北条麻妃一区二区三区中文字幕| 精品视频www| 97视频在线播放| 亚洲国产成人爱av在线播放| 日韩欧美在线中文字幕| 日韩欧美在线看| 中文字幕亚洲无线码在线一区| 日韩精品中文字幕视频在线| 国产精品中文字幕在线| 国产日韩欧美另类| 欧美精品激情在线观看| 国产99久久精品一区二区| 久久久久久久久久久网站| 日韩av不卡电影| 久久久视频免费观看| 日本久久精品视频| 亚洲精品狠狠操| 色偷偷噜噜噜亚洲男人| 91九色精品视频| 精品久久久91| 亚洲美女免费精品视频在线观看| 深夜精品寂寞黄网站在线观看| 久久免费精品日本久久中文字幕| 最近免费中文字幕视频2019| 91精品国产免费久久久久久| 欧美日韩国产中文精品字幕自在自线| 日韩在线播放av| 成人免费视频网址| 亚洲欧美国产高清va在线播| 亚洲www永久成人夜色| 91国产美女视频| 日韩欧美国产黄色| 欧美国产第一页| 夜夜狂射影院欧美极品| 亚洲亚裔videos黑人hd| 日韩专区中文字幕| 欧美交受高潮1| 欧美日韩精品在线|