ajax學習筆記

来源:http://www.cnblogs.com/venoral/archive/2016/01/16/5136508.html
-Advertisement-
Play Games

最近在看《Head First Ajax》,雖然書里代碼給的已經夠詳細了,但在手過一遍代碼時還是引發了一些知識點的思考和擴展。書還沒看完,這篇文章我打算是對於那本書邊看邊總結。 Ajax代碼思路 創建請求對象 配置請求對象併發送到伺服器 伺服器應答請求對象(1) 創建請求對象,作為和伺服器進行通訊的...


最近在看《Head First Ajax》,雖然書里代碼給的已經夠詳細了,但在手過一遍代碼時還是引發了一些知識點的思考和擴展。書還沒看完,這篇文章我打算是對於那本書邊看邊總結。

Ajax代碼思路

  • 創建請求對象

  • 配置請求對象併發送到伺服器

  • 伺服器應答請求對象

    (1) 創建請求對象,作為和伺服器進行通訊的對象:

    function createRequest(){
    try{
    var request=new XMLHttpRequest();
    }catch(tryMS){
    try{
    request=new ActiveXObject("Msxml2.XMLHTTP");
    }catch(otherMS){
    try{
    request=new ActiveXObject("Microsoft.XMLHTTP");
    }catch(failed){
    request=null;
    }
    }
    }
    return request;
    }

    註:ActiveXObject是Microsoft特定的一種編程對象,有兩個不同版本由不同瀏覽器分別支持。XMLHTTP是可以在Javascript等腳本語言中通過http協議傳送或接收XML及其他數據的一套API。
    獲得請求對象request後,它有這麼些個屬性:

    常用的有onreadystatechange,readyState,responseText,status

    這幾天在segmentfault看到一個更詳細的ajax介紹:http://segmentfault.com/a/1190000004322487?utm_source=Weibo&utm_medium=shareLink&utm_campaign=socialShare#articleHeader6 引用過來對我自己的總結加以補充:

    (2)配置請求對象併發送到伺服器:

    var request=createRequest();
    request.open("GET",url,true);
    request.onreadystatechange=showResponse;
    request.send(null);

    open,send方法均來自request對象的原型XMLHttpRequest,打開__proto__:XMLHttpRequest可看到:

    open()方法有三個參數,第一個是發送請求所使用的方法(GET還是POST,區別以後再總結),第二個是規定伺服器端腳本的url(該文件可以是任何類型的文件),第三個參數規定是否進行非同步處理(預設true非同步)
    send()方法將請求送往伺服器。
  • 我在這裡註意到,request.onreadystatechange=showResponse;這句代碼所在的位置不同,控制台輸出的響應內容就不同。想來也是,回調函數加入任務隊列的時機不同肯定輸出不同啊,就比如現在這個位置,request.onreadystatechange=showResponse;在open之後send之前,當代碼解析到request.onreadystatechange=showResponse;時,此時的readyStates=1(請求已和伺服器建立接連),此後當readyStates由1變為2,回調函數showResponse加入任務隊列中等待被執行,readyState從2變化到3,回調函數showResponse第二次加入任務隊列,readyState從3變化到4,回調函數再次加入隊列。所以猜想當執行棧的代碼執行完畢後,控制台會輸出“請求已發送,伺服器已接收,send之後”,“請求正在處理”,“請求已完成”;確實如此:

    (3)伺服器應答請求對象,js就可以處理響應內容了:


    function showResponse(){
    if(request.readyState==0){
    console.log('請求未初始化,調用open之前');
    }else if(request.readyState==1){
    console.log('請求已提出,伺服器連接已建立,open之後send之前');
    }else if(request.readyState==2){
    console.log('請求已發送,伺服器已接收,send之後');
    }else if(request.readyState==3){
    console.log('請求正在處理');
    }else if(request.readyState==4){
    console.log('請求已完成');
    if(request.status==200){
    //處理request.responseText;
    }
    }
    }

    上面代碼僅是為了跟蹤readyState變化,實際項目代碼要不了這麼多。底下才是實際主要代碼:

    function showResponse(){
    if(request.readyState==4){
    if(request.status==200){
    //處理request.responseText;
    }
    }
    }

    參考

  • 《Head First Ajax》
  • 《圖解HTTP》:返回結果的Http狀態碼
  • AJAX-onreadystatechange事件:http://www.w3school.com.cn/ajax/ajax_xmlhttprequest_onreadystatechange.asp
    歡迎各位菊苣來指點交流~


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

-Advertisement-
Play Games
更多相關文章
  • 參考書籍:Head First Java1、假設某方法是別人寫在某個類裡面的2、而此時你根本就不知道這個方法是否有風險(比如伺服器出故障會使程式受到影響);3、那最好的方法應該就是,在調用這個類的方法時,加上可能發生異常的處理方案,未雨綢繆。關鍵字:try……catch,throws,throw,f...
  • Day 2308 Udp接收端09 Udp鍵盤錄入數據方式10 Udp聊天11 TCP傳輸12 TCP傳輸213 TCP練習14 TCP複製文件08 Udp接收端需求:定義一個應用程式,用於接收udp協議傳輸的數據並處理。思路:1.定義UdpSocket服務。2.定義一個數據報包,因為要存儲接收到的...
  • 手動安裝django_chartit庫1 下載壓縮包2 解壓到python安裝目錄下,文件夾名為django_chartit,並檢查文件夾下是否有setup.py文件3 在cmd中進入django_chartit文件夾下,cmd命令為 cd C:\Python27\django_chartit4 輸...
  • 搭建一個簡單的跨平臺C開發的基礎框架, 主要是使用posix線程庫和 自己寫的一個分級 日誌庫,以後可以在這個基礎上搭建你需要的框架會容易一點. 在Window和Linux上測試通過.
  • 服務定位器隱藏了類之間的依賴關係,導致錯誤從編譯時推遲到了運行時,並且,在引入破壞性更改時,這個模式導致代碼不清晰,增加了維護難度。
  • 什麼是微服務 微服務應用的一個最大的優點是,它們往往比傳統的應用程式更有效地利用計算資源。這是因為它們通過擴展組件來處理功能瓶頸問題。這樣一來,開發人員只需要為額外的組件部署計算資源,而不需要部署一個完整的應用程式的全新迭代。最終的結果是有更多的資源可以提供給其它任務。 • 一種軟體架構模式 • 復...
  • 10th Anniversary of jQueryToday marks the 10th anniversary of the release of jQuery...[原文]今天是jQuery發佈十周年. 那時還在上大學,我在2006年紐約的BarCamp上宣佈的。難以想象它會發展到今天這種程...
  • 幾個重要概念,完全是自己的理解。 文件流操作。具體來講就是用createReadStream來代替readFile,這樣做的原因就是讀文件時先要讀入緩衝區buffer,如果文件過大那麼需要的緩衝去也就很大,所以用stream 來代替 。stream大概的工作原理是分成小塊,然後傳輸。 Stream:...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...