jquery中常用的ajac有 $.ajax() , $.post , $.get() ,$.load()了。
例子
代碼如下 |
複製代碼 |
$.post("test.jsp", { name: "cssrain", time: "2008/01/21" }, //要傳遞的資料 function(data){ alert("返回的資料: " + data); } ) |
這個的傳回值就是data了,我們只要在function(data){} 這個匿名函數對返回結果data進入處理即可
例子 $.load()
代碼如下 |
複製代碼 |
$("#loadajax").load("http://www.111cn.net .post", function (responseText, textStatus, XMLHttpRequest){ this;//在這裡this指向的是當前的DOM對象,即$(".ajax.load")[0] }); <div id=loadajax>這樣就會收到load的傳回值了哦</div> |
例子
代碼如下 |
複製代碼 |
$.ajax({ type: "get",//使用get方法訪問後台 dataType: "json",//返回json格式的資料 url: "BackHandler.ashx",//要訪問的後台地址 data: "pageIndex=" + pageIndex,//要發送的資料 complete :function(){$("#load").hide();},//AJAX請求完成時隱藏loading提示 success: function(msg){//msg為返回的資料,在這裡做資料繫結 var data = msg.table; $.each(data, function(i, n){ var row = $("#template").clone(); row.find("#OrderID").text(n.訂單ID); row.find("#CustomerID").text(n.客戶ID); row.find("#EmployeeID").text(n.僱員ID); row.find("#OrderDate").text(ChangeDate(n.訂購日期)); if(n.發貨日期!== undefined) row.find("#ShippedDate").text(ChangeDate(n.發貨日期)); row.find("#ShippedName").text(n.貨主名稱); row.find("#ShippedAddress").text(n.貨主地址); row.find("#ShippedCity").text(n.貨主城市); row.find("#more").html("<a href=OrderInfo.aspx?id=" + n.訂單ID + "&pageindex="+pageIndex+"> More</a>"); row.attr("id","ready");//改變綁定好資料的行的id row.appendTo("#datas");//添加到模板的容器中 }); |
這個就是返回json格式的了
jquery ajax無傳回值
在jquery的ajax方法中,傳遞參數後,回調判斷有success 和 error兩種情況。
有時,在不需要傳回值的情況下,扔按模板格式,設定了dataType:"json",參數;這時候,ajax傳值正確時,出現200返回成功狀態下報錯的特殊情況。
以前沒注意到ajax方法的傳回值資料類型的設定問題。在沒有回傳參數時,一般無需設定傳回值的資料類型。如果設定出錯,一般都報錯。這時候,直接取消 dataType:"json",
無傳回值的ajax方法正確模板:
代碼如下 |
複製代碼 |
$.ajax({ type: "post", url: "index.php", data: "id="+uid, success : function(){ alert(1); }, error: function(){ alert(0); } }); |
例子
jquery的 ajax 驗證使用者名稱。郵箱,驗證碼
代碼如下 |
複製代碼 |
function check_email() { var check_email = $("#reg_mail").val(); var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((/.[a-zA-Z0-9_-]{2,3}){1,2})$/; flag = reg.test(check_email); if(flag) { var email_value = $('#reg_mail').val(); $.get("[var.base_url]register.php",{check_name:"email",check_value:email_value,async:false},function(json){ //$('#res_mail').html(json); if(json == "ok") { $('#res_mail').html("<font color='green' font-size='12'><b>此email可以註冊!</b></font>"); return true; }else{ $('#res_mail').html("<font color='red' font-size='12'><b>此email已被註冊!</b></font>"); return false; } }); }else{ $("#res_mail").html("<font color='red' font-size='12'><b>請輸入正確的郵箱地址!</b></font>"); return false; } } |
開始是這麼寫的。 可是總是無法擷取到返回的狀態true 或false 返回一個undefined 查了很多資料。csdn上的一個文章很經典:
代碼如下 |
複製代碼 |
var boolean = false; $.get(url,null,function(data){//理解這個不難,只要你Crowdsourced Security Testing道jquery中的方法返回的都是jquery的對象或jquery指定的對象。 //jquery的get、post等ajax方法預設是非同步互動方式,所以在get方法還沒有執行完成的時候就已經return了,這時的bl就是你定義的bl = false;所以一直返回false;改成同步的應該有值了 //所以要想放回bl的正確值,你得改下get方法。一般不在ajax方法中做傳回值處理。 //可以用$.data("bl", bl);儲存你的值,然後用$.data("bl")取值。 if(data.indexOf("true")>=0){ $("#mid").html("登陸成功"); bl = true; $.data("bl", bl); } else{ $("#mid").html("使用者名稱或密碼錯誤"); bl = false; $.data("bl", bl); } }); return bl; |
這樣就可以擷取到返回的狀態了。用data方法 儲存 值。然後擷取。還有一個方法就是
代碼如下 |
複製代碼 |
$.get(url,{async: false},function(data) 設定傳輸方式為同步傳輸 |
最終修改函數如下。 測試ok。
代碼如下 |
複製代碼 |
function check_email() { var check_email = $("#reg_mail").val(); var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((/.[a-zA-Z0-9_-]{2,3}){1,2})$/; flag = reg.test(check_email); if(flag) { var email_value = $('#reg_mail').val(); $.get("[var.base_url]register.php",{check_name:"email",check_value:email_value,async:false},function(json){ //$('#res_mail').html(json); if(json == "ok") { $('#res_mail').html("<font color='green' font-size='12'><b>此email可以註冊!</b></font>"); tamp_email = true; $.data("tamp_email",tamp_email); //$('#sub_reg').attr("disabled", false); }else{ $('#res_mail').html("<font color='red' font-size='12'><b>此email已被註冊!</b></font>"); tamp_email = false; $.data("tamp_email",tamp_email); //$('#sub_reg').attr("disabled", true); } }); return tamp_email; }else{ $("#res_mail").html("<font color='red' font-size='12'><b>請輸入正確的郵箱地址!</b></font>"); return false; } } |