溫馨提示×

溫馨提示×

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

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

jQuery Ajax怎么使用

發布時間:2022-10-23 09:38:36 來源:億速云 閱讀:204 作者:iii 欄目:編程語言

本篇內容主要講解“jQuery Ajax怎么使用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“jQuery Ajax怎么使用”吧!

$.post、$.get是一些簡單的方法,如果要處理復雜的邏輯,還是需要用到jQuery.ajax()

一、$.ajax的一般格式

$.ajax({

   type: 'POST',

   url: url ,

  data: data ,

  success: success ,

  dataType: dataType

});

二、$.ajax的參數描述

參數 描述

url必需。規定把請求發送到哪個 URL。
data可選。映射或字符串值。規定連同請求發送到服務器的數據。
success(data, textStatus, jqXHR)可選。請求成功時執行的回調函數。
dataType

可選。規定預期的服務器響應的數據類型。

默認執行智能判斷(xml、json、script 或 html)。

三、$.ajax需要注意的一些地方:

  1.data主要方式有三種,html拼接的,json數組,form表單經serialize()序列化的;通過dataType指定,不指定智能判斷。

  2.$.ajax只提交form以文本方式,如果異步提交包含<file>上傳是傳過不過去,需要使用jquery.form.js的$.ajaxSubmit

四、$.ajax我的實際應用例子

//1.$.ajax帶json數據的異步請求
var aj = $.ajax( { 
  url:'productManager_reverseUpdate',// 跳轉到 action 
  data:{ 
       selRollBack : selRollBack, 
       selOperatorsCode : selOperatorsCode, 
       PROVINCECODE : PROVINCECODE, 
       pass2 : pass2 
  }, 
  type:'post', 
  cache:false, 
  dataType:'json', 
  success:function(data) { 
    if(data.msg =="true" ){ 
      // view("修改成功!"); 
      alert("修改成功!"); 
      window.location.reload(); 
    }else{ 
      view(data.msg); 
    } 
   }, 
   error : function() { 
     // view("異常!"); 
     alert("異常!"); 
   } 
});


//2.$.ajax序列化表格內容為字符串的異步請求
function noTips(){ 
  var formParam = $("#form1").serialize();//序列化表格內容為字符串 
  $.ajax({ 
    type:'post',   
    url:'Notice_noTipsNotice', 
    data:formParam, 
    cache:false, 
    dataType:'json', 
    success:function(data){ 
    } 
  }); 
} 


//3.$.ajax拼接url的異步請求
var yz=$.ajax({ 
   type:'post', 
   url:'validatePwd2_checkPwd2&#63;password2='+password2, 
   data:{}, 
   cache:false, 
   dataType:'json', 
   success:function(data){ 
     if( data.msg =="false" ) //服務器返回false,就將validatePassword2的值改為pwd2Error,這是異步,需要考慮返回時間 
     { 
        textPassword2.html("<font color='red'>業務密碼不正確!</font>"); 
        $("#validatePassword2").val("pwd2Error"); 
        checkPassword2 = false; 
        return; 
      } 
   }, 
   error:function(){} 
}); 


//4.$.ajax拼接data的異步請求
$.ajax({  
  url:'<%=request.getContextPath()%>/kc/kc_checkMerNameUnique.action',  
  type:'post',  
  data:'merName='+values,  
  async : false, //默認為true 異步  
  error:function(){  
    alert('error');  
  },  
  success:function(data){  
    $("#"+divs).html(data);  
  }
});

url: 要求為String類型的參數,(默認為當前頁地址)發送請求的地址。

type: 要求為String類型的參數,請求方式(post或get)默認為get。注意其他http請求方法,例如put和

delete也可以使用,但僅部分瀏覽器支持。

timeout: 要求為Number類型的參數,設置請求超時時間(毫秒)。此設置將覆蓋$.ajaxSetup()方法的全局設

置。

async:要求為Boolean類型的參數,默認設置為true,所有請求均為異步請求。

如果需要發送同步請求,請將此選項設置為false。注意,同步請求將鎖住瀏覽器,用戶其他操作必須等

待請求完成才可以執行。

cache:要求為Boolean類型的參數,默認為true(當dataType為script時,默認為false)。

設置為false將不會從瀏覽器緩存中加載請求信息。

data: 要求為Object或String類型的參數,發送到服務器的數據。如果已經不是字符串,將自動轉換為字符串格

式。get請求中將附加在url后。防止這種自動轉換,可以查看processData選項。對象必須為key/value格

式,例如{foo1:"bar1",foo2:"bar2"}轉換為&foo1=bar1&foo2=bar2。如果是數組,JQuery將自動為不同

值對應同一個名稱。例如{foo:["bar1","bar2"]}轉換為&foo=bar1&foo=bar2。

dataType: 要求為String類型的參數,預期服務器返回的數據類型。如果不指定,JQuery將自動根據http包mime

信息返回responseXML或responseText,并作為回調函數參數傳遞。

可用的類型如下:

xml:返回XML文檔,可用JQuery處理。

html:返回純文本HTML信息;包含的script標簽會在插入DOM時執行。

script:返回純文本JavaScript代碼。不會自動緩存結果。除非設置了cache參數。注意在遠程請求

時(不在同一個域下),所有post請求都將轉為get請求。

json:返回JSON數據。

jsonp:JSONP格式。使用SONP形式調用函數時,例如myurl&#63;callback=&#63;,JQuery將自動替換后一個

“&#63;”為正確的函數名,以執行回調函數。

text:返回純文本字符串。

beforeSend:要求為Function類型的參數,發送請求前可以修改XMLHttpRequest對象的函數,例如添加自定義

HTTP頭。在beforeSend中如果返回false可以取消本次ajax請求。XMLHttpRequest對象是惟一的參

數。

function(XMLHttpRequest){

this; //調用本次ajax請求時傳遞的options參數

}

complete:要求為Function類型的參數,請求完成后調用的回調函數(請求成功或失敗時均調用)。

參數:XMLHttpRequest對象和一個描述成功請求類型的字符串。

function(XMLHttpRequest, textStatus){

this; //調用本次ajax請求時傳遞的options參數

}

success:要求為Function類型的參數,請求成功后調用的回調函數,有兩個參數。

(1)由服務器返回,并根據dataType參數進行處理后的數據。

(2)描述狀態的字符串。

function(data, textStatus){

//data可能是xmlDoc、jsonObj、html、text等等

this; //調用本次ajax請求時傳遞的options參數

error:要求為Function類型的參數,請求失敗時被調用的函數。該函數有3個參數,即XMLHttpRequest對象、錯

誤信息、捕獲的錯誤對象(可選)。

ajax事件函數如下:

function(XMLHttpRequest, textStatus, errorThrown){

//通常情況下textStatus和errorThrown只有其中一個包含信息

this; //調用本次ajax請求時傳遞的options參數

}

contentType:要求為String類型的參數,當發送信息至服務器時,內容編碼類型默認

為"application/x-www-form-urlencoded"。該默認值適合大多數應用場合。

dataFilter:要求為Function類型的參數,給Ajax返回的原始數據進行預處理的函數。

提供data和type兩個參數。data是Ajax返回的原始數據,type是調用jQuery.ajax時提供的

dataType參數。函數返回的值將由jQuery進一步處理。

function(data, type){

//返回處理后的數據

return data;

}

global:要求為Boolean類型的參數,默認為true。表示是否觸發全局ajax事件。設置為false將不會觸發全局

ajax事件,ajaxStart或ajaxStop可用于控制各種ajax事件。

ifModified:要求為Boolean類型的參數,默認為false。僅在服務器數據改變時獲取新數據。

服務器數據改變判斷的依據是Last-Modified頭信息。默認值是false,即忽略頭信息。

jsonp:要求為String類型的參數,在一個jsonp請求中重寫回調函數的名字。

該值用來替代在"callback=&#63;"這種GET或POST請求中URL參數里的"callback"部分,例如

{jsonp:'onJsonPLoad'}會導致將"onJsonPLoad=&#63;"傳給服務器。

username:要求為String類型的參數,用于響應HTTP訪問認證請求的用戶名。

password:要求為String類型的參數,用于響應HTTP訪問認證請求的密碼。

processData:要求為Boolean類型的參數,默認為true。默認情況下,發送的數據將被轉換為對象(從技術角度

來講并非字符串)以配合默認內容類型"application/x-www-form-urlencoded"。如果要發送DOM

樹信息或者其他不希望轉換的信息,請設置為false。

scriptCharset:要求為String類型的參數,只有當請求時dataType為"jsonp"或者"script",并且type是GET時

才會用于強制修改字符集(charset)。通常在本地和遠程的內容編碼不同時使用。

案例代碼:

 $(function(){
 
  $('#send').click(function(){
 
  $.ajax({
 
  type: "GET",
 
  url: "test.json",
 
  data: {username:$("#username").val(), content:$("#content").val()},
 
  dataType: "json",
 
      success: function(data){
 
      $('#resText').empty(); //清空resText里面的所有內容
 
      var html = '';
 
      $.each(data, function(commentIndex, comment){
 
       html += '' + comment['username']+ ':+ '';
      });
 
       $('#resText').html(html);
 
       }
 
  });
 
       });
 
  });

順便說一下$.each()函數:

$.each()函數不同于JQuery對象的each()方法,它是一個全局函數,不操作JQuery對象,而是以一個數組或者對象作為第1個參數,以一個回調函數作為第2個參數?;卣{函數擁有兩個參數:第1個為對象的成員或數組的索引,第2個為對應變量或內容。

到此,相信大家對“jQuery Ajax怎么使用”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

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

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女