国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開發(fā) > AJAX > 正文

Ajax的用法總結(jié)

2024-09-01 08:30:46
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

一、什么是Ajax

Ajax英文全稱為“ Asynchr JavsScript and XML”(異步的JavaScript和XML),是一種創(chuàng)建交互式網(wǎng)頁(yè)的開發(fā)技術(shù)。

二、Ajax技術(shù)的核心

Ajax是一系列相關(guān)技術(shù)的融合,其核心包括XMLHttpRequest、JavsScript和DOM技術(shù),數(shù)據(jù)格式的不同可能會(huì)用到Json或者XML的技術(shù)。

XMLHttpRequest是它的核心的內(nèi)容,它能夠?yàn)轫?yè)面中的JavaScript腳本提供特定的通信方式,從而使頁(yè)面的javascript腳本和服務(wù)器之間形成動(dòng)態(tài)交互的效果,XMLHTTPRequest的最大的優(yōu)點(diǎn)是頁(yè)面內(nèi)的javascript腳本可以不用刷新頁(yè)面,而直接和服務(wù)器發(fā)生交互,從而實(shí)現(xiàn)頁(yè)面無(wú)刷新的效果。

三、XMLHttpRequest方法屬性描述

1、方法描述

abort()停止當(dāng)前請(qǐng)求

getAllResponseHeaders()把HTTP請(qǐng)求的所有響應(yīng)首部作為鍵/值對(duì)返回

getResponseHeader("header")返回指定首部的串值

open("method","URL",[asyncFlag],["userName"],["password"])建立對(duì)服務(wù)器的調(diào)用。method參數(shù)可以是GET、POST或PUT。

url參數(shù)可以是相對(duì)URL或絕對(duì)URL。這個(gè)方法還包括3個(gè)可選的參數(shù),是否異步,用戶名,密碼

send(content)向服務(wù)器發(fā)送請(qǐng)求

setRequestHeader("header", "value")把指定首部設(shè)置為所提供的值。在設(shè)置任何首部之前必須先調(diào)用open()。

設(shè)置header并和請(qǐng)求一起發(fā)送 ('post'方法一定要 )

XMLHttpRequest 對(duì)象屬性描述

2、方法描述

onreadystatechange狀態(tài)改變的事件觸發(fā)器,每個(gè)狀態(tài)改變時(shí)都會(huì)觸發(fā)這個(gè)事件處理器,通常會(huì)調(diào)用一個(gè)JavaScript函數(shù)

readyState請(qǐng)求的狀態(tài)。有5個(gè)可取值:0 = 未初始化,1 = 正在加載,2 = 已加載,3 = 交互中,4 = 完成

responseText服務(wù)器的響應(yīng),返回?cái)?shù)據(jù)的文本。

responseXML服務(wù)器的響應(yīng),返回?cái)?shù)據(jù)的兼容DOM的XML文檔對(duì)象 ,這個(gè)對(duì)象可以解析為一個(gè)DOM對(duì)象。

responseBody服務(wù)器返回的主題(非文本格式)

responseStream服務(wù)器返回的數(shù)據(jù)流

status服務(wù)器的HTTP狀態(tài)碼(如:404 = "文件末找到" 、200 ="成功" ,等等)

statusText服務(wù)器返回的狀態(tài)文本信息 ,HTTP狀態(tài)碼的相應(yīng)文本(OK或Not Found(未找到)等等)

四、Ajax工作原理原理

AJAX的工作原理相當(dāng)于在用戶和服務(wù)器之間加了一個(gè)中間層,使用戶操作與服務(wù)器相應(yīng)異步化。并不是所有的用戶請(qǐng)求

都提交給服務(wù)器,像一些數(shù)據(jù)驗(yàn)證和數(shù)據(jù)處理等都交給AJAX引擎自己來(lái)做,只有確定需要從服務(wù)器讀取新數(shù)據(jù)時(shí)再由

AJAX引擎代為向服務(wù)器提交請(qǐng)求。如圖:

五、Ajax的優(yōu)點(diǎn)

1、減輕服務(wù)器的負(fù)擔(dān),提升了網(wǎng)站的性能。

2、無(wú)刷新更新頁(yè)面,減少了用戶等待網(wǎng)站加載的時(shí)間。

3、用戶體驗(yàn)更加友好,可以避免出現(xiàn)白屏的情況。

4、Ajax是基于標(biāo)準(zhǔn)化并且廣泛使用的技術(shù)幾乎所有的主流瀏覽器都支持該技術(shù),ye不需要單獨(dú)安裝插件。

5、Ajax可以使Web中的頁(yè)面和應(yīng)用分離,便于分工合作。

六、Ajax缺點(diǎn)

1、對(duì)于移動(dòng)設(shè)備不能很好的支持。

2、Ajax干掉了back按鈕,即對(duì)瀏覽器后退機(jī)制的破壞。

3、安全問(wèn)題。比如:跨站點(diǎn)腳步攻擊、SQL注入攻擊和基于credentials的安全漏洞等。

4、對(duì)搜索引擎的支持比較弱。

5、破壞了程序的異常機(jī)制。至少?gòu)哪壳翱磥?lái),像ajax.dll,ajaxpro.dll這些ajax框架是會(huì)破壞程序的異常機(jī)制的。

造成調(diào)試的困難。

七、使用原則

1、Ajax適用場(chǎng)景

表單驅(qū)動(dòng)的交互

深層次的樹的導(dǎo)航

快速的用戶與用戶間的交流響應(yīng)

類似投票、yes/no等無(wú)關(guān)痛癢的場(chǎng)景

對(duì)數(shù)據(jù)進(jìn)行過(guò)濾和操縱相關(guān)數(shù)據(jù)的場(chǎng)景

普通的文本輸入提示和自動(dòng)完成的場(chǎng)景

2、Ajax不適用場(chǎng)景

部分簡(jiǎn)單的表單

搜索

基本的導(dǎo)航

替換大量的文本

對(duì)呈現(xiàn)的操縱

八、原生AJAX寫法

var XHR=null;if (window.XMLHttpRequest) {// 非IE內(nèi)核XHR = new XMLHttpRequest();} else if (window.ActiveXObject) {// IE內(nèi)核,這里早期IE的版本寫法不同,具體可以查詢下XHR = new ActiveXObject("Microsoft.XMLHTTP");} else {XHR = null;}if(XHR){XHR.open("GET", "ajaxServer.action");XHR.onreadystatechange = function () {// readyState值說(shuō)明// 0,初始化,XHR對(duì)象已經(jīng)創(chuàng)建,還未執(zhí)行open// 1,載入,已經(jīng)調(diào)用open方法,但是還沒(méi)發(fā)送請(qǐng)求// 2,載入完成,請(qǐng)求已經(jīng)發(fā)送完成// 3,交互,可以接收到部分?jǐn)?shù)據(jù)// status值說(shuō)明// 200:成功// 404:沒(méi)有發(fā)現(xiàn)文件、查詢或URl// 500:服務(wù)器產(chǎn)生內(nèi)部錯(cuò)誤if (XHR.readyState == 4 && XHR.status == 200) {// 這里可以對(duì)返回的內(nèi)容做處理// 一般會(huì)返回JSON或XML數(shù)據(jù)格式console.log(XHR.responseText);// 主動(dòng)釋放,JS本身也會(huì)回收的XHR = null;}};XHR.send();}

以上所述是小編給大家介紹的Ajax的用法總結(jié),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)武林網(wǎng)網(wǎng)站的支持!

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 华阴市| 多伦县| 泰顺县| 和田市| 石门县| 雷山县| 土默特左旗| 玛曲县| 石首市| 卓尼县| 寿宁县| 沂水县| 于都县| 济源市| 会昌县| 绥德县| 广汉市| 梁山县| 黑河市| 清涧县| 四子王旗| 玉溪市| 土默特右旗| 龙口市| 四会市| 玉山县| 阳山县| 通榆县| 千阳县| 桃园县| 拜城县| 班玛县| 庆城县| 蓬安县| 治县。| 平定县| 湛江市| 固原市| 金门县| 汉寿县| 金门县|