当前位置:  编程技术>jquery

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

    来源: 互联网  发布时间:2014-10-08

    本文导语:  jquery ajax 返回值有很多类型,包括html,text,json,xml等类型,这些值都可以在ajaxp处理是直接使用匿名函数来直接获取。 以下整理了几个jquery ajax 返回值的例子。 jquery中常用的ajac有 $.ajax() , $.post , $.get() ,$.load()了。 例子:   代...

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. .post",
function (responseText, textStatus, XMLHttpRequest){
this;//在这里this指向的是当前的DOM对象,即$(".ajax.load")[0]
});
这样就会收到load的返回值了哦

例子: 
 

代码示例:
$.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(" More");
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("此email可以注册!");
return true;
}else{
$('#res_mail').html("此email已被注册!");
return false;
}
});
}else{
$("#res_mail").html("请输入正确的邮箱地址!");
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) 设置传输方式为同步传输
 

最终修改函数: 
 

代码示例:
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("此email可以注册!");
tamp_email = true;
$.data("tamp_email",tamp_email);
//$('#sub_reg').attr("disabled", false);
}else{
$('#res_mail').html("此email已被注册!");
tamp_email = false;
$.data("tamp_email",tamp_email);
//$('#sub_reg').attr("disabled", true);
}
});
return tamp_email;
}else{
$("#res_mail").html("请输入正确的邮箱地址!");
return false;
}
}

    
 
 

您可能感兴趣的文章:

  • firefox下jquery ajax返回object XMLDocument处理方法
  • Jquery each方法跳出循环,并获取返回值(实例讲解)
  • JQuery 返回布尔值Is()条件判断方法学习
  • jquery左边浮动到一定位置时显示返回顶部按钮
  • 解决jquery中post方法返回404错误的问题
  • jquery让返回的内容显示在特定div里(代码少而精悍)
  • 使用jquery实现IE下按backspace相当于返回操作
  • jquery与css实现返回顶部的效果代码
  • 用jQuery实现的智能隐藏、滑动效果的返回顶部代码
  • jquery的ajax异步请求接收返回json数据实例
  • jquery返回顶部效果(兼容IE6)的实现代码
  • Jquery ajax调用action返回值的问题
  • jQuery实现返回顶部功能适合不支持js的浏览器
  • jquery序列化form表单使用ajax提交后处理返回的json数据
  • jquery实现返回顶部的例子
  • JQuery处理json与ajax返回JSON实例代码
  • jQuery学习笔记之jQuery.fn.init()的参数分析
  • jQuery学习笔记之jQuery.extend(),jQuery.fn.extend()分析
  • jquery 单引号和双引号的区别分析
  • jquery $(document).ready()与window.onload的区别分析
  • jQuery中的正则表达式分析 正则基础
  • jquery异步请求并改变页面内容的实例分析
  • jquery的$(document).ready()与onload的加载顺序分析
  • Jquery的ready和Dom的onload的区别分析
  • jquery结合cookie实现自动登录的方法分析
  • Jquery children与find的区别分析
  • 对 jQuery 中 data 方法的误解分析
  • jquery淡入淡出效果原理分析
  • JQuery EasyUI 加载两次url的原因分析及解决方案
  • jQuery选择器-Sizzle之工作原理分析
  • Jquery getJSON方法详细分析
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • jQuery-ui引入后Vs2008的无智能提示问题解决方法
  • jquery动态添加元素事件失效问题解决方法
  • MVC2 jQuery的验证时,关于客户端验证绑定复选框问题。
  • 自定义jquery模态窗口插件无法在顶层窗口显示问题
  • jquery库或JS文件在eclipse下报错问题解决方法
  • 巧用jquery解决下拉菜单被Div遮挡的相关问题
  • 解决自定义$(id)的方法与jquery选择器$冲突的问题
  • 解决jQuery动态获取手机屏幕高和宽的问题
  • 浅析jQuery中调用ajax方法时在不同浏览器中遇到的问题
  • 关于jQuery判断元素是否存在的问题示例探讨
  • jquery组件使用中遇到的问题整理及解决
  • jquery选择checked在ie8普通模式下的问题
  • 解决jquery操作checkbox火狐下第二次无法勾选问题
  • jquery中ajax函数执行顺序问题之如何设置同步
  • 快速解决jquery之get缓存问题的最简单方法介绍
  • 解决Jquery鼠标经过不停滑动的问题
  • 探讨JQUERY JSON的反序列化类 using问题的解决方法
  • jquery动态改变onclick属性导致失效的问题解决方法
  • jquery attr方法获取input的checked属性问题
  • 浅析JQuery UI Dialog的样式设置问题
  • 通过javascript库JQuery实现页面跳转功能代码
  • jQuery鼠标动画插件 jquery-ahover
  • jQuery概述,代码举例及最新版下载
  • jQuery向导插件 Jquery Wizard Plugin
  • HTML教程 iis7站长之家
  • jQuery圆角插件 jQuery Corners
  • struts+spring+hibernate+jquery实现分页功能的几个基本类介绍(异步加载)
  • jQuery相册插件 jQuery.popeye
  • jQuery UI组件 jQuery UI
  • jQuery右键菜单插件 jQuery ContextMenu
  • jQuery分页插件 Pagination jQuery Plugin


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3