如何學(xué)習(xí)Ajax框架

本篇文章為大家展示了如何學(xué)習(xí)Ajax 框架,內(nèi)容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細(xì)介紹希望你能有所收獲。

成都創(chuàng)新互聯(lián)公司專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、六盤水網(wǎng)絡(luò)推廣、小程序開發(fā)、六盤水網(wǎng)絡(luò)營銷、六盤水企業(yè)策劃、六盤水品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運(yùn)營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們最大的嘉獎(jiǎng);成都創(chuàng)新互聯(lián)公司為所有大學(xué)生創(chuàng)業(yè)者提供六盤水建站搭建服務(wù),24小時(shí)服務(wù)熱線:18980820575,官方網(wǎng)址:bm7419.com

一.XMLHttpRequest 對象的三個(gè)重要的屬性。

onreadystatechange屬性

onreadystatechange 屬性存有處理服務(wù)器響應(yīng)的函數(shù)。下面的代碼定義一個(gè)空的函數(shù),可同時(shí)對 onreadystatechange 屬性進(jìn)行設(shè)置:

xmlHttp.onreadystatechange=function()
{
  // 我們需要在這里寫一些代碼
  }

readyState屬性

readyState 屬性存有服務(wù)器響應(yīng)的狀態(tài)信息。每當(dāng) readyState 改變時(shí),onreadystatechange 函數(shù)就會(huì)被執(zhí)行。

這是 readyState 屬性可能的值:

狀態(tài)

描述

0

請求未初始化(在調(diào)用 open() 之前)

1

請求已提出(調(diào)用 send() 之前)

2

請求已發(fā)送(這里通常可以從響應(yīng)得到內(nèi)容頭部)

3

請求處理中(響應(yīng)中通常有部分?jǐn)?shù)據(jù)可用,但是服務(wù)器還沒有完成響應(yīng))

4

請求已完成(可以訪問服務(wù)器響應(yīng)并使用它)

我們要向這個(gè) onreadystatechange 函數(shù)添加一條 If 語句,來測試我們的響應(yīng)是否已完成(意味著可獲得數(shù)據(jù)):

xmlHttp.onreadystatechange=function()
  {
  if(xmlHttp.readyState==4)
    {
    // 從服務(wù)器的response獲得數(shù)據(jù)
    }
  }

responseText屬性

可以通過 responseText 屬性來取回由服務(wù)器返回的數(shù)據(jù)。

二.基本源碼:

var xmlHttp
 
function showCustomer(str)
{
xmlHttp=GetXmlHttpObject();
if (xmlHttp==null)
  {
  alert ("Your browser does not support AJAX!");
  return;
  }
//設(shè)置請求響應(yīng)的url
var url="getcustomer_xml.asp";
url=url+"?q="+str;
url=url+"&sid="+Math.random();
 
xmlHttp.onreadystatechange=stateChanged;
xmlHttp.open("GET",url,true);
xmlHttp.send(null);
}
 
function stateChanged()
{
if (xmlHttp.readyState==4)
{
//responseText 以字符串返回 HTTP 響應(yīng)
//document.getElementById("txtHint").innerHTML=xmlHttp.responseText;
 
//responseXML 以 XML 返回響應(yīng)
//服務(wù)器端ContentType 屬性為 response 對象設(shè)置了 HTTP 內(nèi)容類型。該屬性的默認(rèn)值是 "text/html"。服務(wù)器端返回responseXML 要把內(nèi)容類型設(shè)置為 XML。
var xmlDoc=xmlHttp.responseXML.documentElement;
document.getElementById("companyname").innerHTML=
xmlDoc.getElementsByTagName("compname")[0].childNodes[0].nodeValue;
document.getElementById("contactname").innerHTML=
xmlDoc.getElementsByTagName("contname")[0].childNodes[0].nodeValue;
document.getElementById("address").innerHTML=
xmlDoc.getElementsByTagName("address")[0].childNodes[0].nodeValue;
document.getElementById("city").innerHTML=
xmlDoc.getElementsByTagName("city")[0].childNodes[0].nodeValue;
document.getElementById("country").innerHTML=
xmlDoc.getElementsByTagName("country")[0].childNodes[0].nodeValue;
}
}
 
function GetXmlHttpObject()
{
var xmlHttp=null;
try
  {
  // Firefox, Opera 8.0+, Safari
  xmlHttp=new XMLHttpRequest();
  }
catch (e)
  {
  // Internet Explorer
  try
    {
    xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
    }
  catch (e)
    {
    xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
  }
return xmlHttp;
}

三.Ajax框架:基于瀏覽器的應(yīng)用框架,基于服務(wù)器端的應(yīng)用框架。

1.基于瀏覽器的應(yīng)用框架一般分為兩種:

Aplication frameworks:提供了瀏覽器功能,但其最著名的還是在于通過窗口生成組件建立桌面GUI。 如:DOJO,qooxdoo,JavaFX,YUI,ExtJS(最開始的名字是yui-ext,因?yàn)閿U(kuò)展了yui的庫,后來發(fā)展為可選擇擴(kuò)展jquery和prototype就改名字為ext),F(xiàn)lex(與ExtJS有很多相似),TIBET等。

Infrastructural frameworks:提供基本的框架功能和輕便式瀏覽器端操作,讓開發(fā)者去創(chuàng)建具體應(yīng)用,主要功能包括:

  •  

    • 基于XMLHttpRequest組件的瀏覽器交互功能

    • XML解析和操作功能

    • 根據(jù)XMLHttpRequest的返回信息進(jìn)行相應(yīng)的DOM操作

    • 一些特殊情況下,和其他的瀏覽器端技術(shù)如Flash(或Java Applets)等集合到一起應(yīng)用

如:jQuery(代碼量少),prototype,MooTools(功能比prototype強(qiáng)大,設(shè)計(jì)比prototype完善,從prototype中汲取很多有益的設(shè)計(jì)理念),Google AJAXSLT,F(xiàn)lash/JavaScript,等。

2.基于服務(wù)器端的應(yīng)用框架通常以下面兩種方式工作(盡管它們根據(jù)不同的語言進(jìn)行了分類) :

HTML/JS Generation(HTML/JS生成):通過服務(wù)器端生成HTML和JS代碼在傳遞給瀏覽器端進(jìn)行直接運(yùn)行 。如:Ext GWT。

遠(yuǎn)程交互:JavaScript調(diào)用服務(wù)器端函數(shù)(例如調(diào)用Java函數(shù))并返回給JavaScript的回調(diào)句柄,或者請求服務(wù)器端數(shù)據(jù)信息,例如Session信息,數(shù)據(jù)庫查詢等。 如DWR。

上述內(nèi)容就是如何學(xué)習(xí)Ajax 框架,你們學(xué)到知識或技能了嗎?如果還想學(xué)到更多技能或者豐富自己的知識儲(chǔ)備,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

本文名稱:如何學(xué)習(xí)Ajax框架
轉(zhuǎn)載來源:http://bm7419.com/article16/jjcdgg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供標(biāo)簽優(yōu)化、網(wǎng)站排名企業(yè)網(wǎng)站制作、網(wǎng)站收錄Google、營銷型網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都seo排名網(wǎng)站優(yōu)化