Jquery在异步提交方面封装的很好,直接用AJAX非常麻烦,Jquery大大简化了我们的操作,不用考虑浏览器的诧异了。
推荐一篇不错的jQuery Ajax 实例文章,忘记了可以去看看,
地址为:http://www.cnblogs.com/yeer/archive/2009/07/23/1529460.html 和 http://www.w3school.com.cn/jquery/
$.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?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);
}
});
达维营-前端网