溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何使用jQuery的ajax方法向服務器發(fā)出get和post請求

發(fā)布時間:2021-08-09 09:36:50 來源:億速云 閱讀:114 作者:小新 欄目:web開發(fā)

這篇文章主要介紹如何使用jQuery的ajax方法向服務器發(fā)出get和post請求,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

打算寫個ajax系列的博文,主要是寫給自己看,學習下ajax的相關(guān)知識和用法,以更好的在工作中使用ajax。

假設有個網(wǎng)站A,它有一個簡單的輸入用戶名的頁面,界面上有兩個輸入框,第一個輸入框包含在一個form表單里用來實現(xiàn)form提交,第二個輸入框是單獨的、沒有包含在form里,下面就用這兩個輸入框來學習下jQuery的ajax。

如何使用jQuery的ajax方法向服務器發(fā)出get和post請求

1,前端的html和javascript代碼

頁面html

<main >
   <h3>輸入用戶名</h3>
   <form class="" action="demo01.php" method="post" >
   <input id="user-name" type="text" name="username" placeholder="請?zhí)顚懩挠脩裘?quot;>
    <input type="submit" name="submit1" value="form提交1" class="input">
   </form>
   <input id="user-name2" type="text" name="username2" placeholder="請?zhí)顚懩挠脩裘?quot;>
   <input type="button" name="submit2" value="ajax提交2">
   <div class="box">
   </div>
  </main>
  <script src="../../js/jquery-3.1.0.min.js"></script>
  <script src="demo.js"></script>

頁面中引入的demo01.js代碼,注意此處實現(xiàn)的是一個簡單的GET請求。

 $(function($) {
  $('input[name=submit2]').on('click', function(e) {
   let username = '';
   if ('' !== (username = $('#user-name2').val())) {
    $.ajax({
     url: `demo.php?name=${username}`,
     dataType: 'json',
     method: 'GET',
     success: function(data) {
      if (data.result == 1) {
       $('.box').html(`<div>你的姓名${username}已成功保存。</div>`);
      }
     },
     error: function(xhr) {
      // 導致出錯的原因較多,以后再研究
      alert('error:' + JSON.stringify(xhr));
     }
    })
    .done(function(data) {
     // 請求成功后要做的工作
     console.log('success');
    })
    .fail(function() {
     // 請求失敗后要做的工作
     console.log('error');
    })
    .always(function() {
     // 不管成功或失敗都要做的工作
     console.log('complete');
    });
   }
  });
 });

jQuery的ajax()方法有兩種寫法,分別是: $.ajax(url [, settings]); 和 $.ajax([settings]); 兩種寫法都可以,感覺第一種方法適合用于參數(shù)較少的情況,比如,如果只是對一個url做一個簡單的請求,不對返回的數(shù)據(jù)、格式和錯誤有要求,只需要傳遞一個url參數(shù)就可以,那就可以用第一種寫法。上面的demo01.js中采用的是第二種寫法,下面解釋下參數(shù)和相關(guān)的函數(shù)。

(1)上面代碼中ajax()的參數(shù)

可以看到這里的參數(shù)類型都是javascript對象,即都是 o = {key: value}; 這種類型的數(shù)據(jù)。jQuery的文檔中規(guī)定了,這里的參數(shù)只能是PlainObject(對象類型的對象),不能是null、自定義的數(shù)組、或者像docement這種歸屬于某種執(zhí)行環(huán)境(比如瀏覽器)屬于某種類型的對象。這里不太好說清楚,可以做個小試驗。在命令行里打開node repl,進行下測試:

> node
 > typeof(null);
 'object'
 > typeof([]);
 'object'
 > typeof(document);
 'undefined'
 > typeof({});
 'object'

可以看到null、[](數(shù)組類型)、{}(對象類型)都是對象。因為在js中一切皆對象。而在交互式環(huán)境中,document則是未定義的一個變量,所以它的類型是undefined。如果在瀏覽器環(huán)境下測試下typeof(document),那么它的類型也是object。下面逐個解釋下代碼用到的參數(shù):

url,要請求的url地址,它的值應該是包含url的字符串。

dataType,字符串。發(fā)出請求后,期望從服務器返回的數(shù)據(jù)類型。可以指定的類型有xml、html、script、json、jsonp、text。如果不指定,jquery會基于MIME做判斷,并會返回一個下面xml、json、script、html當中的一種類型。

method,字符串。HTTP請求方法,默認為GET,上面代碼中指定為POST。

success, Type: Function( Anything data, String textStatus, jqXHR jqXHR ) ,匿名函數(shù)。HTTP請求成功后要調(diào)用的函數(shù),可以傳遞三個參數(shù)給它:從服務器返回的數(shù)據(jù)(如果上面指定了dataType,則服務器返回的數(shù)據(jù)類型需要與上面dataType指定的類型一致)、一個可以描述狀態(tài)的字符串textStatus、還有一個jqXHR對象??梢钥吹缴厦嬷粋鬟f了從服務器返回的數(shù)據(jù)data。

error, Type: Function( jqXHR jqXHR, String textStatus, String errorThrown ) ,匿名函數(shù)。HTTP請求失敗后要調(diào)用的函數(shù),同樣也可以傳遞三個參數(shù)。

除了用到的這些參數(shù),還有許多其他的如:async、dataFilter、mimeType等其他參數(shù),不過現(xiàn)在的這個簡單的腳本還用不到那么多參數(shù)。

(2)“延遲加載函數(shù)”

上面代碼中 $.ajax().done().fail().always() jqXHR.done()、jqXHR.fail()、jqXHR.always()中分別可以添加deferred對象被解析、被拒絕、被解析或被拒絕這三種情況下的要處理的工作,比如添加個函數(shù)什么的。為什么能夠這么做呢,這要看$.ajax()返回了什么,它返回的是jqXHR對象(jquery版本大于1.5時)。這個對象實現(xiàn)了Promise interface(Promise機制,用來傳遞異步操作消息,代表了某個未來才會知道結(jié)果的事件)。這就允許在一次請求中添加多個回調(diào)函數(shù),甚至可以在請求完成后添加回調(diào)函數(shù)。

標題“延遲加載”描述的不夠準確,但從效果上看是有延遲加載的效果。關(guān)于這個問題更詳細的解釋可以參考jQuery文檔中對jqXHR的解釋  或一位前端前輩的解釋jQuery的deferred對象詳解 。

 2,后端運行在nginx服務器上的php代碼

后端的邏輯很簡單:我們把前端獲取的數(shù)據(jù)保存到名為data-demo01的文件中,保存成功則向前端返回一個1作為標志。

(1)前端ajax發(fā)起GET請求

如果前端的ajax發(fā)起的是一個GET請求,那么后端也比較好處理:

  if (isset($_GET['name']) && !empty($_GET['name'])) {
   $username = trim($_GET['name']);
   if (file_put_contents('data-demo01', $username)) {
    echo '{"result": 1}';
   } 
}

(2)前端ajax發(fā)起POST請求

js代碼中需要修改下ajax()的url、method參數(shù),并增加一個data參數(shù),修改后如下:

 // 相同的代碼省略
 $.ajax({
  url: `demo01.php`,
  dataType: 'json',
  method: 'POST',
  data: {"username": username},
 // 相同的代碼省略

因為用POST傳遞數(shù)據(jù),所以去掉url中用來傳遞數(shù)據(jù)的參數(shù),下面的data類型要與dataType一致,為json格式,然后將username作為值傳遞。

那么后端的代碼也就可以確定了:

 if (isset($_POST['username']) && !empty($_POST['username'])) {
   $username = trim($_POST['username']);
   if (file_put_contents('data-demo01', $username)) {
    echo '{"result": 1}';
   }
  }

如果不出錯的話,效果應該是下面這樣然后查看下data-demo01,名字果然被保存了。

如何使用jQuery的ajax方法向服務器發(fā)出get和post請求

以上是“如何使用jQuery的ajax方法向服務器發(fā)出get和post請求”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI