欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于異步請求ajax原理以及原生Ajax、$.ajax的基本使用詳解

 更新時間:2023年05月17日 09:37:05   作者:禿頭披風(fēng)俠.  
這篇文章主要介紹了關(guān)于異步請求ajax原理以及原生Ajax、$.ajax的基本使用詳解,ajax現(xiàn)在是前后端交互的重要工具,可以說,只要從事于it行業(yè),ajax那就是必須要掌握的一名技術(shù),下面我們就來對ajax進行介紹,需要的朋友可以參考下

ajax原理介紹

什么是ajax

ajax是Asynchronous Javascript And XML的簡寫,意思就是異步的javascript和xml,也就是異步請求?,F(xiàn)在主要用于前后端進行交互,從而實現(xiàn)動態(tài)網(wǎng)頁,異步更新。

ajax的優(yōu)點

在傳統(tǒng)的html中,當(dāng)我們向服務(wù)器發(fā)送數(shù)據(jù)后,頁面會發(fā)生跳轉(zhuǎn),如果我們使用ajax,那么就可以在不發(fā)生跳轉(zhuǎn)的情況下實現(xiàn)前后端的交互,從而實現(xiàn)數(shù)據(jù)的更新,進而實現(xiàn)局部頁面更新。

ajax的應(yīng)用場景

我們直接看一個最典型的案例,這就用到了ajax技術(shù)。

上面是一個搜索框,我們進行搜索的時候,下面就自動進行提示,這就是ajax的典型應(yīng)用案例,我們只要輸入字符,那么就會發(fā)送ajax請求,服務(wù)器返回數(shù)據(jù),頁面再進行展示。

ajax的應(yīng)用場景很多,可以說,現(xiàn)在和后端通信,基本都是使用ajax來進行了。

ajax原理分析

  1. 我們自己定義觸發(fā)事件,在觸發(fā)事件里面編寫ajax代碼
  2. 當(dāng)事件觸發(fā)時,游覽器將會發(fā)送ajax異步請求,本質(zhì)還是http請求
  3. 服務(wù)器返回數(shù)據(jù),我們通過回調(diào)函數(shù)來對返回數(shù)據(jù)進行處理
  4. 將數(shù)據(jù)展示到頁面上,實現(xiàn)局部更新

使用ajax

我們這里介紹原生的ajax和jquery使用ajax,現(xiàn)在還有十分流行的axious,這個的原理也是ajax,我們把ajax好,學(xué)習(xí)其他異步請求也就輕松了。

原生ajax

我們使用原生的ajax,首先要創(chuàng)建XMLHttpRequest 對象,這個對象就可以用來實現(xiàn)異步請求。

var xhr = new XMLHttpRequest();

我們創(chuàng)建對象后就可以使用該對象的方法,我們使用open方法,這個方法可以指定請求的方法,請求的地址,參數(shù),以及是同步還是異步請求。open(method,url,async)

xhr.open("GET","http://localhost:8080/ajax/userServlet?username=jack",true)

上面的代碼表示我們使用get方式請求,請求的地址是http//localhost:8080/ajax/userServlet,參數(shù)為username,值為jack,最后一個參數(shù)true表示使用異步請求,如果填false,那么就是同步請求。

xhr.onreadystatechange = function(){};

onreadystatechange,這個就是用來指定回調(diào)函數(shù)的,也就是當(dāng)請求成功后,我們要做的事情。

ajax請求有好幾個狀態(tài),readyState,readyState保存在XMLHttpRequest中,不同的值表示不同狀態(tài)。

  • 0: 請求未初始化
  • 1: 服務(wù)器連接已建立
  • 2: 請求已接收
  • 3: 請求處理中
  • 4: 請求已完成,且響應(yīng)已就緒

我們在一般情況下,都是對readyState=4來進行操作

除了readyState,我們都知道,在http響應(yīng)中有一個狀態(tài)碼,其中200表示成功,在ajax中也是一樣,XMLHttpRequest對象中有一個屬性為status,這個就是響應(yīng)的狀態(tài)碼。所以,我們在進行編寫回調(diào)函數(shù)的時候就可以寫成下面那樣。

          xhr.onreadystatechange = function () {
            if (xhr.readyState === 4 && xhr.status === 200){
                //代碼段
            }
          }

我們在大多數(shù)情況下都是寫成上面那樣。

對于服務(wù)器返回的數(shù)據(jù),我們使用XMLHttpRequest的responseText就可以進行接收(不能是xml),接收到值后進行處理。

var text = xhr.responseText;

我們把上面的代碼都寫好后,最后一步就是發(fā)送ajax請求,這個很簡單,直接使用send方法即可。

xhr.send();

完整的一個原生ajax請求代碼如下:

    <script>
        window.onload = function () {
            //給按鈕添加點擊事件
            document.getElementById("btn1").onclick = function () {
                //創(chuàng)建一個XMLHttpRequest對象
                var xhr = new XMLHttpRequest()
                //請求的方式,url,異步請求
                xhr.open("GET", "/ajax/userServlet?username=jack", true)
                xhr.onreadystatechange = function () {
                    //當(dāng)請求已完成,且響應(yīng)已就緒并且狀態(tài)碼為200的時候我們認為正常響應(yīng)了
                    if (xhr.readyState === 4 && xhr.status === 200) {
                        //得到響應(yīng)的數(shù)據(jù)
                        var text = xhr.responseText;
                    }
                }
                xhr.send();
            }
        }
    </script>

jquery使用ajax

上面使用原生ajax還是比較麻煩的,現(xiàn)在我們就使用jquery的ajax請求方式。

$.ajax()

這個方法是jquery編寫ajax的寫法,里面?zhèn)魅胍粋€對象,對象中以key:value來填寫參數(shù)$.ajax({name:value, name:value, ... }),常見的參數(shù)如下:

  • type:規(guī)定請求的類型(GET 或 POST)。
  • url:規(guī)定發(fā)送請求的 URL。默認是當(dāng)前頁面。
  • data:規(guī)定要發(fā)送到服務(wù)器的數(shù)據(jù)。
  • dataType:預(yù)期的服務(wù)器響應(yīng)的數(shù)據(jù)類型。
  • beforeSend(xhr):表示發(fā)送請求前運行的函數(shù)。
  • success(result,status,xhr):當(dāng)請求成功時運行的函數(shù)。一般只使用第一個參數(shù),第一個參數(shù)表示響應(yīng)的數(shù)據(jù)
  • error(xhr,status,error):如果請求失敗要運行的函數(shù)。
  • complete(xhr,status):請求完成時運行的函數(shù)(在請求成功或失敗之后均調(diào)用,即在 success 和 error 函數(shù)之后)。

上面是一些常見的屬性,詳細信息請參考jquery ajax,下面給出一個$.ajax()的使用。

        //綁定點擊事件
        $("#btn1").click(function () {
            $.ajax({
                url: "http://localhost:8080/ajax/userServlet",//請求的網(wǎng)址
                type: "post", //請求方式
                data: { //請求數(shù)據(jù)
                    username: 'jack',
                },
                error: function () { //失敗后的回調(diào)函數(shù)
                    console.log("失敗~")
                },
                success: function (data) {//成功后的回調(diào)函數(shù)
                    console.log("成功:" + data);
                },
                dataType: "json" //響應(yīng)的類型
            })
        })

$.get()

上面的$.ajax()還是有些復(fù)雜,我們?yōu)榱撕喕?,可以直接使?.get(),這個方法只有4個參數(shù),寫法為 $.get(URL,data,function(data,status,xhr),dataType),我們只需要按照順序?qū)懢托辛耍?個參數(shù)分別表示請求地址,請求數(shù)據(jù),成功后的回調(diào)函數(shù),響應(yīng)類型。

其中,url是必須要寫的,其他都是可選項。請求方法為get,下面給出一個$.get()的寫法。

            $.get("http://localhost:8080/ajax/userServlet", {
                username: 'jack'
            }, function (data) {
                console.log("請求成功 "+ data)
            }, "json")

這種寫法功能和上面一樣,但是簡潔了很多。

$.post()

這個方法和$.get()基本是一樣的,就是請求的方法不一樣,其他都一樣,直接按照$.get()使用即可。

總結(jié)

我們在這篇文章中介紹了ajax,ajax的作用,工作原理等,并且還使用原生ajax和jquery的ajax來進行編程,學(xué)完后,相信大家已經(jīng)對ajax有了大致認識,當(dāng)然,這篇文章只介紹了ajax的一小部分內(nèi)容,也是最常用的,想要深入了解,還得要通過系統(tǒng)學(xué)習(xí)才行。

到此這篇關(guān)于關(guān)于異步請求ajax原理以及原生Ajax、$.ajax的基本使用詳解的文章就介紹到這了,更多相關(guān)ajax原理與原生ajax內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論