jquery ajax返回值与无返回值问题

   jquery ajax 返回值有很多类型如有html,text,json,xml类型了,我们这些值都可以在ajaxp处理是直接使用匿名函数来直接获取,下面我整理内个jquery ajax 返回值的例子给各位参考参考。

  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+">&nbsp;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){//理解这个不难,只要你先知道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;
}
}

时间: 2024-10-24 17:15:40

jquery ajax返回值与无返回值问题的相关文章

jquery ajax php保存数据并返回值

<!doctype html public "-//w3c//dtd xhtml 1.0 transitional//en" "http://www.w3.org/tr/xhtml1/dtd/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="content-

理解jquery ajax中的datatype属性选项值_AJAX相关

jquery中ajax的dataType属性用于指定服务器返回的数据类型,如果不指定,jQuery 将自动根据HTTP包MIME信息来智能判断,如果datatype选项不填写的话,会将返回的数据当成字符串处理. 一.ajax语法 复制代码 代码如下: jQuery.ajax([settings]) 参数说明 settings:用于配置 Ajax 请求的键值对集合.可以通过 $.ajaxSetup() 设置任何选项的默认值. 二.ajax的datatype选项的值 1."xml":返回

理解jquery ajax中的datatype属性选项值

jquery中ajax的dataType属性用于指定服务器返回的数据类型,如果不指定,jQuery 将自动根据HTTP包MIME信息来智能判断,如果datatype选项不填写的话,会将返回的数据当成字符串处理. 一.ajax语法 复制代码 代码如下: jQuery.ajax([settings]) 参数说明 settings:用于配置 Ajax 请求的键值对集合.可以通过 $.ajaxSetup() 设置任何选项的默认值. 二.ajax的datatype选项的值 1."xml":返回

jquery + ajax +smarty+php 无刷新删除数据代码

jquery + ajax +smarty+php教程 无刷新删除数据代码 写个js:view sourceprint?01 02 function delItem (id) {  03 $.get('delete.php?id='+id,null,function (msg) {//ajax请求,请求后执行下面<SPAN class=t_tag onclick=tagshow(event) href="tag.php?name=%B4%FA%C2%EB">代码</S

jquery ajax 接收返回值 是个URL 字符串,为空,在线等

问题描述 jquery ajax 接收返回值 是个URL 字符串,为空,在线等 jquery ajax 接收返回值 是个URL 字符串,为空,后台debug看了,肯定传了. 前台接收类型'text'.没啥问题,是否有其他原因 解决方案 上代码呀.不然怎么排查原因 解决方案二: jQuery.ajax({ type:'post', url:"/financeReport/generateURL.do", cache:false, data:{"reportType":

jquery ajax return没有返回值的解决方法_jquery

大家先看一段简单的jquery ajax 返回值的js 复制代码 代码如下: function getReturnAjax{ $.ajax({ type:"POST", url:"ajax/userexist.aspx", data:"username="+vusername.value, success:function(msg){ if(msg=="ok"){ showtipex(vusername.id,"&l

jquery ajax jsp 返回值乱码二向解决方法

jquery ajax 网页特效p/jsp.html target=_blank >jsp教程 返回值乱码二向解决方法在以前开发ajax时经常会碰到乱码,今天我们用jquery ajax+jsp时,又出来乱码了,经常测试找到了二种处理jquery ajax乱码问题,下面看看. <script> $().ready(function(){ var url="/www.111cn.net/ajaxgetnewsclassfather.do"; var pars="

asp.net jquery ajax返回值并输出

asp教程.net jquery ajax返回值并输出 本文章是讲一款关于jquery ajax返回值如何让asp.net教程接收并且输出实例代码. <script language="网页特效" src="js/jquery-1.3.2.min.js"></script>      <script type="text/javascript">          var url = "webform

Jquery each方法跳出循环,并获取返回值实例讲解

 这篇文章主要是对Jquery each方法跳出循环,并获取返回值进行了详细的介绍,需要的朋友可以过来参考下,希望对大家有所帮助 return false:将停止循环 (就像在普通的循环中使用 'break'). return true:跳至下一个循环(就像在普通的循环中使用'continue').  代码如下: function test(){ var success = false; $(..).each(function () {    if (..) {        success =