如果你是想 ajax提交带文件的表单,那真的没法做,
10年积累的成都网站建设、成都网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有睢县免费网站建设让你可以放心的选择与我们合作。
基本都是用iframe模拟 异步提交的···
jquery.form.js 提交带文件的表单,也是 用iframe模拟 异步提交的
$("#btnUpload").click(function () {
8 if ($("#flUpload").val() == "") {
9 alert("请选择一个图片文件,再点击上传。");
10 return;
11 }
12 $('#UpLoadForm').ajaxSubmit({
13 success: function (html, status) {
14 var result = html.replace("pre", "");
15 result = result.replace("/pre", "");
16 $("#image").attr('src', result);
17 alert(result);
18 }
19 });
20 });
在form表单中添加id:form id="formId"/form,
buttom按钮进行提交,加onclick="js函数",
然后在js函数中$("#formId").submit()。
第一步:引用js
!--这里的min是自己用js压缩工具对完整版进行的压缩
并不是真正的min,所以好使--
script type="text/javascript" src="js/jquery-1.7.min.js"/script
script type="text/javascript" src="js/jquery.form.js"/script
第二步:页面写form
form id="showDataForm"
action="/024pm/f_shopUser.do?method=login" method="post"
input type="text" value="" name="name" maxlength="2"/
input type="password" value="" name="password" maxlength="2"/
input type="submit" value="提交"/
/form
div id="output1"
style="width:1000px;height:200px;"
/div
第三步:写js调用jquery.form.js,对form表单进行ajax提交
$(document).ready(function() {
var options = {
target: '#output1',
// 从服务传过来的数据显示在这个div内部
也就是ajax局部刷新
beforeSubmit: showRequest,
// ajax提交之前的处理
success: showResponse
// 处理之后的处理
};
$('#showDataForm').submit(function() {
$(this).ajaxSubmit(options);
return false;
//非常重要,如果是false,则表明是不跳转
//在本页上处理,也就是ajax,如果是非false,则传统的form跳转。
});
});
function showResponse(responseText, statusText, xhr, $form) {
alert(xhr.responseText+"=="+$form.attr("method")+'status: ' +
statusText + '\n\nresponseText: \n' + responseText);
//xhr:说明你可以用ajax来自己再次发出请求
//$form:是那个form对象,是一个jquery对象
//statusText:状态,成功则为success
//responseText,服务器返回的是字符串(当然包括html,不包括json)
}
function showRequest(formData, jqForm, options) {
//formData是数组,就是各个input的键值map数组
//通过这个方法来进行处理出来拼凑出来字符串。
//formData:拼凑出来的form字符串,比如name=herapassword,
//其实就是各个表单中的input的键值对,
//如果加上method=XXXX,那也就是相当于ajax内的data。
var queryString = $.param(formData);
alert(queryString+"======"+formData.length);
for (var i=0; i formData.length; i++) {
alert(formData[i].value+"==============="+formData[i].name);
}
//jqForm,jquery form对象
var formElement = jqForm[0];
alert($(formElement).attr("method"));
alert($(jqForm[0].name).attr("maxlength"));
//非常重要,返回true则说明在提交ajax之前你验证
//成功,则提交ajax form
//如果验证不成功,则返回非true,不提交
return true;
}
options对象内的值有哪些?
var options = {
target: '#output1',
data:{param1:"我自己的第一个额外的参数"},
//这个参数是指通过ajax来给服务器提交除了form内部input的参数
//在后台中使用String param1=req.getParameter("param1");获取。
// dataType: null,
dataType:'json',
//这个参数值的是服务器返回的数据类型,默认的是null
//也就是服务器可以默认返回字符串,然后将这些字符串放在target内部
//当然还有json、xml,其中最常用的便是null和json
//对于span style="color: #333333;"a href="" target="_blank"span style="color: #333333;"json/span/a/span的使用,我们会稍后讲解到
beforeSubmit: showRequest,
success: successRes,
type:'POST'
//提交方式,默认是自己在form标签上指定的method
//如果没有指定,则使用get。
url:''
//重新提交的url,即url可以在form中配置
//也可以在这里配置。
};