AJAX的工作原理

来源:http://www.cnblogs.com/charade/archive/2017/09/15/7529189.html
-Advertisement-
Play Games

1:在講ajax的原理之前我們先簡單的瞭解一下ajax的背景 可否認,ajax技術的流行得益於google的大力推廣,正是由於google、gmail等對ajax技術的廣泛應用,才催生了ajax的流行。而這也讓微軟感到無比的尷尬,因為早在97年,微軟便已經發明瞭ajax中的關鍵技術,並且在99年IE ...



1:在講ajax的原理之前我們先簡單的瞭解一下ajax的背景

 可否認,ajax技術的流行得益於google的大力推廣,正是由於google、gmail等對ajax技術的廣泛應用,才催生了ajax的流行。而這也讓微軟感到無比的尷尬,因為早在97年,微軟便已經發明瞭ajax中的關鍵技術,並且在99IE5推出之時,它便開始支持XmlHttpRequest對象,並且微軟之前已經開始在它的一些產品中應用ajax,遺憾的是,不知道出於什麼想法,當時微軟發明瞭ajax的核心技術之後,並沒有看到它的潛力而加以發展和推廣,而是將它擱置起來。正是這一次的失誤,成就了它現在的競爭對手googleajax方面的領先地位,而事實上google目前在ajax技術方面的領先是微軟所無法達到的,現在微軟也意識到了這個問題,因此它也開始在ajax領域奮起直追,比如說推出它自己的ajax框架atlas,並且在.NET2.0也提供了一個用來實現非同步回調的介面,即ICallBack介面。

2:關於AJAX的名字 

ajax的全稱是Asynchronous JavaScript and XML 其中Asynchronus是非同步的意思,他有別於傳統web開發中採取的同步方式。同步在這裡就不做詳細的介紹了,有興趣的朋友可以自己查一下文檔。

 3:AJAX所包含的技術

大家都知道ajax並不是一種新的技術,而是幾種原有技術的結合體。它是由下列技術的結合而成。

 1:使用CSS和XMTML來展示

2:使用DOM模型來交換和動態的效果顯示

3:使用XMLHttpRequest和伺服器進行非同步通信 

4:使用JavaScript來進行綁定和調用

在上面的幾種技術中,除了XMLHttpRequest對象以外,其它所有的技術都是基於web標準並且已經得到了廣泛的應用,XMLHttpRequest對象雖然目前還沒有被W3C所採納,但是它已經是一個事實的標準,因為目前幾乎所有的主流瀏覽器都支持它。

 4:AJXA原理和XMLHttpRequest對象

 ajax的原理簡單來說就是通過XMLHttpRequest對象來向伺服器發送非同步請求,從伺服器獲取數據,然後用javascript來操作dom元素進行跟新頁面,這個過程中最關鍵的一步就是從伺服器獲取請求數據,要清楚這個過程和原理,我們必須對XMLHttpRequest對象有所瞭解。

 XMLHttpRequest是ajax的核心機制,它是在IE5中首先引入的,是一種支持非同步請求數據的技術,簡單的說,也就是javascript可以及時向伺服器提出請求和處理響應,而不阻塞用戶。達到頁面無刷新的效果。

所有我們先從XMLHttpRequest這個對象說起,看看它是怎麼工作的 

XMLHttpRequest對象的屬性有:

onreadystatechange  每次狀態改變所觸發的事件的事件處理程式

responseText  從伺服器進程返回數據的數據形式

 responseXML  從伺服器進程返回的DOM相容的文檔數據對象

status  從伺服器返回的數字代碼,比如常見的404未找到和200以就緒

status Text  狀態碼的字元串信息
readyState 對象的狀態值

0(未初始化) 對象已經建立,但是尚未初始化沒有調用open方法

1(對象初始化) 對象已經建立,尚未調用send方法

2(發送數據) send方法已經調用,但是當前的狀態及http頭未知

3(數據傳送中) 客服端已經接受一些數據,因為響應頭http不全,這時通過responseBody和responseTest獲取數據可能部分數據會出現錯誤

4(結束數據完成)數據接收完畢,此時可以通過responseXml和responseText獲取伺服器返回的完整數據了 

 但是,由於各瀏覽器之間存在差異,所以創建一個XMLHttpRequest對象可能需要不同的方法。這個差異主要體現在IE和其它瀏覽器之間。下麵是一個比較標準的創建XMLHttpRequest對象的方法。

 

 



您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 【大聖看玩多時,問土地道:“此樹有多少株數?”土地道:“有三千六百株。前面一千二百株,花微果小,三千年一熟,人吃了成仙了道,體健身輕。中間一千二百株,層花甘實,六千年一熟,人吃了霞舉飛升,長生不老。後面一千二百株,紫紋緗核,九千年一熟,人吃了與天地齊壽,日月同庚。”大聖聞言,歡喜無任,當日查明瞭株樹 ...
  • 目前已定義的java設計模式細分下來有二十餘種,這篇博客主要是想從大家所熟知的孫悟空入手,闡述各個設計模式的概念和優缺點,以及他們之間的聯繫。 在下麵介紹的每個設計模式里,都會有與孫悟空相關的具體案例,主要是為了方便大家理解與記憶,否則使用一些枯燥的例子,很難讓人印象深刻。 按筆者的理解,設計模式的 ...
  • 1目的 規範開發模式過程,指導項目研發、質控測試、DevOps的相關活動。 2適用範圍 本規範的作用範圍是為互聯網軟體產品相關項目開發模式的管理過程。 (1) 對項目團隊中研發人員在開發模式過程中的活動、職責等方面進行了指導; (2) 對項目團隊中質控測試在開發模式過程中的活動、職責等方面進行了指導 ...
  • MySQL應用軟體以及環境安裝(Navicat軟體) 百度雲盤鏈接分享: 鏈接: https://pan.baidu.com/s/1o8UMiro 密碼: 8pdu ...
  • 定義: 定義一個操作中演算法的框架,而將一些步驟延遲到子類中。模板方法模式使得子類可以不改變一個演算法的結構即可重定義該演算法的某些特定步驟。 UML類圖: 具體代碼: 模塊說明: AbstractClass:抽象類,定義整個流程演算法的骨架。ConcreteClass:具體類,實現流程演算法里的具體步驟。 ...
  • Keepalived實現雙機熱備: 雙機熱備一般指的是兩台機器設備同時在運行,但是只有一臺處於提供服務的狀態。當其中一臺設備出現故障,那麼另一臺設備接管角色,繼續提供服務,他們之間的切換時間非常之短,基本是無縫切換,所以避免了因為某台伺服器出現故障,導致系統軟體不能正常運行的問題。 · Keepal ...
  • Rafy是什麼可以通過下麵博客來瞭解 Rafy 領域實體框架演示(3) - 快速使用 C/S 架構部署 - BloodyAngel - 博客園 以下是看源碼中的一點記錄,供以後學習使用 主要是Rafy中IOC容器的定義,實現方式,用法 下麵先看一個圖: 這個圖片包含,三個方面的內容 下麵主要從IOb ...
  • 學習怎樣創建對象是理解面向對象編程的第一步,第二步是理解繼承。在傳統的面向對象編程語言中,類繼承其他類的屬性。然而,JS的繼承方式與傳統的面向對象編程語言不同,繼承可以發生對象之間,這種繼承的機制是我們已經熟悉的一種機制:原型。 1.原型鏈接和Object.prototype js內置的繼承方式被稱 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...