JavaScript學習總結 Ajax和Http狀態字

来源:http://www.cnblogs.com/wzhiq896/archive/2016/09/25/5904884.html
-Advertisement-
Play Games

Ajax及其工作原理 AJAX 是一種與伺服器交換數據無需刷新網頁的技術,最早由Google公司在谷歌地圖裡使用,並迅速風靡。 AJAX是不能跨域的,如需跨域,可以使用document.domain='a.com';或者使用伺服器代理,代理XMLHttpRequest文件 AJAX是基於現有的Int ...


Ajax及其工作原理

AJAX 是一種與伺服器交換數據無需刷新網頁的技術,最早由Google公司在谷歌地圖裡使用,並迅速風靡。

AJAX是不能跨域的,如需跨域,可以使用document.domain='a.com';或者使用伺服器代理,代理XMLHttpRequest文件

AJAX是基於現有的Internet標準,並且聯合使用它們:

XMLHttpRequest 對象 (非同步的與伺服器交換數據)
JavaScript/DOM (信息顯示/交互)
CSS (給數據定義樣式)
XML (作為轉換數據的格式)

創建 XMLHttpRequest 對象

所有現代瀏覽器(IE7+、Firefox、Chrome、Safari 以及 Opera)均內建 XMLHttpRequest 對象。

創建Ajax對象:

//IE6以上
var oAjax = new XMLHttpRequest();

//IE6
var oAjax =new ActiveXObject("Microsoft.XMLHTTP")

連接伺服器

oAjax.open(方法,url,是否非同步)

我們都知道,Ajax即“Asynchronous Javascript And XML”(非同步JavaScript和XML),是指一種創建互動式網頁應用的網頁開發技術。所以,Ajax天生就是工作在非同步模式的(非同步為true,同步false)

同步和非同步

同步是指:發送方發出數據後,等接收方發迴響應以後才發下一個數據包的通訊方式。 
非同步是指:發送方發出數據後,不等接收方發迴響應,接著發送下個數據包的通訊方式。 
(簡單點說:同步就是只能一件一件事的來做,而非同步就是可以多件事同時進行)

發送請求send()

<script type="text/javascript">
function getDoc(){
    var xmlhttp;
    if(window.xmlhttpRequest){
        xmlhttp=new XMLHttpRequest();
    }
    else{
        xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");//for IE6
    }
    xmlhttp.onreadystatechange = function(){
        if(xmlhttp.readyState==4&&xmlhttp.status==200){
            document.getElementById("myId").innerHTML=xmlhttp.responseText;
        }
    }
    xmlhttp.open("GET", index.php,true);
    xmlhttp.send();
}
</script>
</head>
<body>
    <button type="button" onclick="getDoc()">請求數據</button>
</body>
 

GET 還是 POST?

與 POST 相比,GET 更簡單也更快,並且在大部分情況下都能用。

然而,在以下情況中,請使用 POST 請求:

無法使用緩存文件(更新伺服器上的文件或資料庫)
向伺服器發送大量數據(POST 沒有數據量限制)
發送包含未知字元的用戶輸入時,POST 比 GET 更穩定也更可靠

接收返回信息

oAjax.onreadystatechange = function(){   //當請求狀態改變時要調用的事件處理器

    alert(oAjax.readystate);           

}

只要readyState屬性的值發生變化時,便會觸發一次readyStatechange事件。可以利用這個事件來檢測每次狀態變化後readyState的值。通常,我們只對readyState值為4的階段感興趣,因為這時所有數據都已經就緒,不過,必須在調用open()之前指定onreadystatechange事件處理程式才能確保跨瀏覽器相容性。下麵來看一個例子:

var xhr = createXHR();
xhr.onreadystatechange = function () {
    if (xhr.readyState == 4) {
        if ((xhr.status >= 200 && xhr.status < 300) || xhr.status == 304) {
            alert(xhr.statusText);
        } else {
            alert("Request was unsuccessful: " + xhr.status);
        }
    }
};
xhr.open("get", "example.txt", true);
xhr.send(null);

XHR對象

XMLHttpRequest這個對象的屬性:

它的屬性有:

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

responseText     從伺服器進程返回數據的字元串形式。
responseXML    從伺服器進程返回的DOM相容的文檔數據對象。

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

status Text       伴隨狀態碼的字元串信息

當XHR對象把一個HTTP請求發送到伺服器的過程中會經歷幾個狀態,直到請求被處理,然後才接收一個回應。readyState就是XHR請求的狀態屬性,它本身有5個屬性值:

0(未初始化)還沒有調用open()方法
1(載入)已調用send()方法,正在發送請求
2(載入完成)send()方法完成,已收到全部響應內容
3(解析)正在解析響應內容
4(完成)響應內容解析完成,可以再客戶端使用了

http狀態碼

1字頭:消息。這一類型的狀態碼,代表請求已被接受,需要繼續處理。
2字頭:成功。這一類型的狀態碼,代表請求已成功被伺服器接收、理解、並接受。
3字頭:重定向。這類狀態碼代表需要客戶端採取進一步的操作才能完成請求。
4字頭:客戶端錯誤。這類狀態碼代表了客戶端看起來可能發生錯誤,妨礙了伺服器的處理。
5字頭:伺服器錯誤。這類狀態碼代表了伺服器在處理請求的過程中有錯誤或者異常狀態發生

另附:http狀態碼詳解
w3cschool HTTP 狀態消息:http://www.w3school.com.cn/tags/html_ref_httpmessages.asp

status和statusText

  statusText是響應返回的文本信息,僅當readyState值為3或4的時候才能使用。當readyState為其它值時視圖存取statusText屬性將引發異常。

XHR的方法

方法描述
abort() 導致當前正在執行的請求被取消
getAllResponseHeaders() 返回包含所有響應頭的名稱和值的單個字元
getResponseHeader(name) 返迴響應頭中指定的名稱和值
open(method,url,async,username,pwd) 設置HTTP方法(get或post)等
send(content) 發出帶有指定主體內容的請求
setRequestHeader(name,value) 使用指定的名稱和值設置請求頭

 

<script type="text/javascript">
        var oAjax =oAjax();
        alert(oAjax.readyState);//彈出"0"
        oAjax.open("get","index.html",true);
        alert(oAjax.readyState);//彈出"1"
        oAjax.send(null);
        alert(oAjax.readyState);//IE下彈出4,而firefox是2
        //可以通過readystatechange事件監聽
        oAjax = XHR();
        oAjax.onreadystatechange = function () {
            alert(oAjax.readyState);//Firefox下依次是1,2,3,4但最後還會再來個1
            //IE下則是1,1,3,4
        };
        oAjax.open("get","index.txt",true);
        oAjax.send(null);
</script>

jQuery中的Ajax

.load()方法是局部方法,因為他需要一個包含元素的jQuery對象作為首碼,而$.get()$.post()是全局方法,無需指定某個元素,對於用途而言,.load()適合做靜態文件的非同步獲取,而對於需要傳遞參數到伺服器頁面的,$.get()$.post()更加合適。

GET和POST傳入的data是一個鍵值對 對象,不同的是GET傳入的data是通過地址欄傳輸的,而POST是通過表單提交的,

$(function () {
    $("input").click(function () {
        $.get('test.php?url=baidu.com', function (response,status,xhr) {
            $('#box').html(response);
        })
    })
});

POST提交不能使用url傳參。post提交可以使用字元串形式的鍵值對形式傳參,自動轉換為http消息實體傳參

$(function () {
    $("input").click(function () {
        $.post('test.php','url=baidu.com', function (response,status,xhr) {
            $('#box').html(response);
        })
    })
});
//post提交可以使用對象鍵值對

$(function () {
    $("input").click(function () {
        $.post('test.php',{
                url:'baidu.com'//post提交可以使用對象鍵值對
            }, function (response,status,xhr) {
            $('#box').html(response);
        })
    })
});

$.get()方法有四個參數,前面三個參數和.load()一樣,多了一個第四參數type,即伺服器返回的內容格式,包括xml,json,script,html,text等,第一個參數為必選參數,後面三個為可選參數

$.ajax()是所有Ajax方法中最底層的方法,所有其他方法都是基於$.ajax()方法的封裝,這個方法只有一個參數,傳遞一個
各個功能鍵值對的對象。

$.ajax()方法對象參數列表

參數類型說明
url string 發送請求的地址
type string 請求方法,預設GET
timeout Number 設置請求超時的時間
data Object或String 發送到伺服器的對象,鍵值對字元串或對象
datatype String 返回的數據類型,比如html,XML,json等
success Function 請求成功後調用的回調函數
complete Function 請求完成後調用的回調函數
error Function 請求失敗後調用的回調函數
$(function () {
    $("input").click(function () {
        $.ajax({
            type : "POST",
            url: 'test.php',
            data:{
                url: 'baidu.com'
            },
            success : function(response,status,xhr){
                $('#box').html(response);
            }
        })
    })
});

表單序列化

Ajax用的最多的地方莫過於表單操作,而傳統的表單操作是通過submit提交將數據傳輸到伺服器,如果使用Ajax非同步處理
的話,我們需要將每個表單元素獲取才能提交,這樣工作效率就大大降低

<body>
<form action="">
    用戶名: <input type="text" name="user" />
    郵件: <input type="text" name="email" />
    <input type="button" value="提交"/>
</form>
<div id="box"></div>
<script type="text/javascript">
    $(function () {
        $("form input[type=button]").click(function () {
            $.ajax({
                type: 'POST',
                url: 'test.php',
                data: {
                    user: $('form input[name=user]').val(),
                    email: $("form input[name=email]").val(),
                },
                success: function(response){
                    $("#box").html(response);
                }
            })
        })
    });
</script>
</body>

表單元素特別多的情況下應採用表單序列化,即data:$(“form”).serialize();//得到的是字元串鍵值對,並且對url進行編碼

serialize()方法不但可以序列化表單內的元素,還可以直接獲取單選框,覆選框和下拉列表框等內容

<body>
<form action="">
    用戶名: <input type="text" name="user" />
    郵件: <input type="text" name="email" />
    <input type="button" value="提交"/>
    <input type="radio" name="sex" value="男"/>男
    <input type="radio" name="sex" value="女"/>女
    <input type="button" value="submit"/>
</form>
<div id="box"></div>
<script>
    $(function () {
        $("form input[name=sex]").click(function () {
            $('#box').html(decodeURIComponent($(this).serialize()));
        })
    })
</script>
</body>

傳統Ajax問題

傳統的ajax有如下的問題:

 
1、可以無刷新改變頁面內容,但無法改變頁面URL

2、為了更好的可訪問性,內容發生改變後,通常改變URL的hash

3、hash的方式不能很好的處理瀏覽器的前進、後退等問題

4、進而瀏覽器引入了onhashchange的介面,不支持的瀏覽器只能定時去判斷hash是否改變

5、但這種方式對搜索引擎很不友好

6、twitter和google約定了使用#!xxx(即hash第一個字元為!),搜索引擎進行支持。

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

-Advertisement-
Play Games
更多相關文章
  • 使用Java多線程編程時經常遇到主線程需要等待子線程執行完成以後才能繼續執行,那麼接下來介紹一種簡單的方式使主線程等待。 java.util.concurrent.CountDownLatch 使用countDownLatch.await()方法非常簡單的完成主線程的等待: ...
  • 烏龜與兔子進行賽跑,跑場是一個矩型跑道,跑道邊可以隨地進行休息。烏龜每分鐘可以前進3米,兔子每分鐘前進9米;兔子嫌烏龜跑得慢,覺得肯定能跑贏烏龜,於是,每跑10分鐘回頭看一下烏龜,若發現自己超過烏龜,就在路邊休息,每次休息30分鐘,否則繼續跑10分鐘;而烏龜非常努力,一直跑,不休息。假定烏龜與兔子在 ...
  • 序 最近琢磨著要寫點東西,把基本的Java Web開發流程完整地走一遍,最後決定,乾脆就寫一個小小的項目實戰吧。這個小項目作為一個JavaWeb的入門例子,從前臺頁面到項目發佈,把整個流程走通。所謂 麻雀雖小,五臟俱全 。難度不是很高,正好可以作為入門使用。 接下來就是做什麼的問題了,首先不能太簡單 ...
  • 1 package test; 2 //i++ 先取值後運算 int i=4; int j=i++; i=5;j=4; 3 //++i 先運算後取值 int i=4;int j=++i; i=5;j=5; 4 public class Test6 { 5 public static void mai ...
  • 建議79:集合中的哈希碼不要重覆 在一個列表中查找某值是非常耗費資源的,隨機存取的列表是遍歷查找,順序存儲的列表是鏈表查找,或者是Collections的二分法查找,但這都不夠快,畢竟都是遍歷嘛,最快的還要數以Hash開頭的集合(如HashMap、HashSet等類)查找,我們以HashMap為例, ...
  • 1、原型結構圖 代碼 3、談談淺複製和深複製 淺複製:被覆制對象的所有變數都含有與原來的對象相同的值,而所有的對其他對象的引用都仍指向原來的對象 深複製:把原來引用對象的變數指向複製過來的新對象,而不是原來被原有的被引用的對象 深拷貝和淺拷貝,會發生深拷貝的是java 的 8種基本數據類型和他們的封 ...
  • 很多書上對設計模式的講解很詳細,可過一段時間就忘記了,這是我對設計模式的理解,便於記憶 單一設計原則:形象的比喻為照相機與手機,手機雖然功能多,但照相效果比不上功能單一的照相機 開-閉原則:軟體實體(類,模塊等)應該擴展,但不可修改 依賴倒置原則:抽象不應該依賴於細節,細節應該依賴於抽象,高層模塊不 ...
  • 1、簡單工廠模式如圖 代碼: 缺點:簡單工廠模式需要客戶端認識兩個類,Cash和CashFactory 優點:子類的實例化被工廠封裝了起來,客戶端看不到 2、策略模式如圖 代碼: 缺點:客戶端(測試端)完全暴露了實現的子類 優點:策略模式的優點是簡化了單元測試,因為每一個演算法都有自己的類,可以通過自 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...