浅析jQuery Ajax请求参数和返回数据的处理


Posted in Javascript onFebruary 24, 2016

刚接触学会用jQuery ajax的时候,觉得真东西好神奇,这样就可以把数据取回来了啊。然后我可以把取回来的数据渲染到页面上,一颗赛艇。

之前很早接触到项目,并不知道怎么优雅的去用jquery ajax(现在也不优雅);

那个时候看别人写的代码

$.post("","",...)

也有

$.get("","",...)

还有

$.ajax()

当然现在知道点,这些写法都是一个意思,还是习惯用 $.ajax() 写写吧。

之前的数据处理,发送数据请求(json的数据格式),然后自己通过下面的方式

var request = {};
request.name = $(".name").val();
request.age = $(".age").val();
request.sex = $(".sex").val();
//...

当时表单发送的参数项少,所以没觉得什么,到后来一个表单很多项数,也这么写,结果 request 就手工写了好多行,虽然能用吧,但是看看这样的代码就觉着哪里不对劲吧,至少很不“优雅”。

后来,发现其实jquery有个 serialize 的方法可以序列化表单数据,可以省事很多。

w3c_jquery_serialize-demo

处理返回数据,渲染到页面上去。

之前的做法也是和上面一模一样的吧,返回的数据是json数据格式的,然后分别取值赋值给页面元素,所以代码往往是这样的。

  浅析jQuery Ajax请求参数和返回数据的处理

如果数据再多点,真的是感觉略难看。其实应该是有更好的做法的,返回的是一个json对象,所以我们可以通过遍历对象的属性值取到所有值然后依次渲染到页面对应元素即可。

对象遍历可以用 for-in 来写(有更好的方法来写么?)

$.ajax({
//...
success:function(result){
for(var v in result){
// 如果渲染的元素都是统一的输入框形式的话,
$("form").find("input[name="+ v +"]").val(result[v]); 
// 如果有其他元素 则另外单独校验处理
}
}
})

上面name(或者其他tag在页面中先写好,和返回数据的属性一致)。

jQuery中ajax的4种常用请求方式

1.$.ajax()返回其创建的 XMLHttpRequest 对象。

$.ajax() 只有一个参数:参数 key/value 对象,包含各配置及回调函数信息。详细参数选项见下。

如果你指定了 dataType 选项,请确保服务器返回正确的 MIME 信息,(如 xml 返回 "text/xml")。

实例:

保存数据到服务器,成功时显示信息。

$.ajax({
type: "post",
dataType: "html",
url: '/Resources/GetList.ashx',
data: dataurl,
success: function (data) {
if (data != "") {
$("#pager").pager({ pagenumber: pagenumber, pagecount: data.split("$$")[1], buttonClickCallback: PageClick });
$("#anhtml").html(data.split("$$")[0]);

}
}
});

2.通过远程 HTTP GET 请求载入信息。

这是一个简单的 GET 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。如果需要在出错时执行函数,请使用 $.ajax。

实例:

$.get("test.cgi", { name: "John", time: "2pm" },
function(data){
alert("Data Loaded: " + data);
});

3. 通过远程 HTTP POST 请求载入信息。

这是一个简单的 POST 请求功能以取代复杂 $.ajax 。请求成功时可调用回调函数。如果需要在出错时执行函数,请使用 $.ajax。

实例:

$.post("/Resources/addfriend.ashx", { "fid": fids, "fname": fnames, "tuid": tuids, "tuname": tunames }, function (data) {
if (data == "ok") {
alert("添加成功!");
}
})

4.通过 HTTP GET 请求载入 JSON 数据。

实例:

$.getJSON("http://api.flickr.com/services/feeds/photos_public.gne?tags=cat&tagmode=any&format=json&jsoncallback=?",
function(data){
$.each(data.items, function(i,item){
$("<img/>").attr("src", item.media.m).appendTo("#images");
if ( i == 3 ) return false;
});
});

以上内容是小编给大家介绍的jQuery Ajax请求参数和返回数据的处理,希望对大家有所帮助!

Javascript 相关文章推荐
用js实现下载远程文件并保存在本地的脚本
May 06 Javascript
传智播客学习之java 反射
Nov 22 Javascript
jQuery + Flex 通过拖拽方式动态改变图片的代码
Aug 03 Javascript
JavaScript立即执行函数的三种不同写法
Sep 05 Javascript
js中日期的加减法
May 06 Javascript
jquery Easyui快速开发总结
Aug 20 Javascript
浅析JS运动
Dec 28 Javascript
JavaScript数据结构之广义表的定义与表示方法详解
Apr 12 Javascript
基于vue-ssr的静态网站生成器VuePress 初体验
Apr 17 Javascript
微信小程序自定义组件的实现方法及自定义组件与页面间的数据传递问题
Oct 09 Javascript
layui按条件隐藏表格列的实例
Sep 19 Javascript
微信小程序基于高德地图查找位置并显示文字
Oct 30 Javascript
jQuery+formdata实现上传进度特效遇到的问题
Feb 24 #Javascript
JQuery EasyUI的使用
Feb 24 #Javascript
使用jQuery监听DOM元素大小变化
Feb 24 #Javascript
JavaScript中的闭包
Feb 24 #Javascript
jQuery中判断对象是否存在的方法汇总
Feb 24 #Javascript
jquery中键盘事件小结
Feb 24 #Javascript
javascript实现九宫格相加数值相等
May 28 #Javascript
You might like
ThinkPHP3.1新特性之对Ajax的支持更加完善
2014/06/19 PHP
php魔术变量用法实例详解
2014/11/13 PHP
php计算给定日期所在周的开始日期和结束日期示例
2017/02/06 PHP
PHP封装cURL工具类与应用示例
2019/07/01 PHP
jQuery库与其他JS库冲突的解决办法
2010/02/07 Javascript
javascript日期格式化示例分享
2014/03/05 Javascript
javascript框架设计之框架分类及主要功能
2015/06/23 Javascript
Javascript农历与公历相互转换的简单实例
2016/10/09 Javascript
KnockoutJS 3.X API 第四章之表单submit、enable、disable绑定
2016/10/10 Javascript
jQuery对table表格进行增删改查
2020/12/22 Javascript
微信小程序 跳转传参数与传对象详解及实例代码
2017/03/14 Javascript
protractor的安装与基本使用教程
2017/07/07 Javascript
微信小程序 rich-text的使用方法
2017/08/04 Javascript
JS运动特效之任意值添加运动的方法分析
2018/01/24 Javascript
详解vue.js根据不同环境(正式、测试)打包到不同目录
2018/07/13 Javascript
Element-UI中Upload上传文件前端缓存处理示例
2019/02/21 Javascript
微信小程序使用npm包的方法步骤
2019/08/13 Javascript
uploadify插件实现多个图片上传并预览
2019/09/30 Javascript
JavaScript中常用的3种弹出提示框(alert、confirm、prompt)
2020/11/10 Javascript
在Django框架中设置语言偏好的教程
2015/07/27 Python
Django的分页器实例(paginator)
2017/12/01 Python
使用Python微信库itchat获得好友和群组已撤回的消息
2018/06/24 Python
python中ASCII码字符与int之间的转换方法
2018/07/09 Python
使用python切片实现二维数组复制示例
2019/11/26 Python
python使用docx模块读写docx文件的方法与docx模块常用方法详解
2020/02/17 Python
中国跨境在线时尚零售商:Bellelily
2018/04/06 全球购物
类的返射机制中的包及核心类
2016/09/12 面试题
初中三年毕业生的自我评价分享
2014/02/14 职场文书
人力资源管理专业应届生求职信
2014/04/24 职场文书
赞美老师的演讲稿
2014/05/22 职场文书
电子商务求职信
2014/06/15 职场文书
2014年语文教研组工作总结
2014/12/06 职场文书
2015年圣诞节活动总结
2015/03/24 职场文书
2016年大学迎新晚会工作总结
2015/10/15 职场文书
Nginx Rewrite使用场景及配置方法解析
2021/04/01 Servers
vue生命周期钩子函数以及触发时机
2022/04/26 Vue.js