菜单

Ajax表单异步上传文件实例代码(包蕴文件域),ajax上传文件

2019年5月18日 - XML

1.起因

Ajax表单异步上传文件实例代码(包蕴文件域),ajax上传文件

1.起因

做前台页面时,必要调用WebAPI的Post请求,发送一些字段和文件(也正是把表单通过ajax异步发送出去,获得再次回到结果),然后拿走重回值判别是或不是成功。

2.尝试

首先尝试了弹指间 “jQuery Form Plugin”
,这个人便是的光辉的坑,完毕他和jquery1.九.二包容性就不是太好,好不轻便把$.browser的主题素材解决了,开选拔她上传文件得不到重回值。

$("#view").submit(
$("#view").ajaxSubmit({
type: "post",
url: "../api/Article/Add",
dataType: "json",
success: function (msg) {
console.log(msg);
},
error: function (msg) {
$("#resultBox").html("连接服务器失败");
console.log(msg);
}
})
);

诸如上边的代码,但是怎么布局,只要上传了文件,success里面再次来到的msg一定是null(chromium浏览器下),但实际上是有重临值的,而且未有公文时也是常规的。更吓人的是IE/EDGE下提醒下载那多少个Json重返值。

翻了瞬间jquery.form.js的源代码,发现她是用Iframe达成的伪Ajax,不清真,Pass!

// are there files to upload?
var files = $('input:file', this).fieldValue();
var found = false;
for (var j=0; j < files.length; j++)
if (files[j]) 
found = true;
if (options.iframe || found) // options.iframe allows user to force iframe mode
fileUpload();
else
$.ajax(options);

那是有无文件时,分别调用一个不等的函数。

3.消除方案

通过多反调查,发掘xhr(XMLHttpRequest)是个好东西。经过测试主流浏览器和手提式有线电话机浏览器都援助这几个事物。下边介绍一下在jquery/zepto的ajax
获取原生XMLHttpRequest
对象上传表单(文件)的艺术。参照作品:http://www.bkjia.com/article/91267.htm

function AjaxForm(formID, options) {
var form = $(formID);
//将form对象直接作为参数 new FormData对象
var formData = new FormData(form[0]);
$("input[type='file']").forEach(function (item, i) {
//获取file对象 即相当于可以直接post的$_FILES数据
var domFile = $(item)[0].files[0];
//追加file 对象
formData.append('file', domFile);
})
if (!options)options = {};
options.url = options.url ? options.url : form.attr("action");
options.type = options.type ? options.type : form.attr("method");
options.data = formData;
options.processData = false; // tell jQuery not to process the data
options.contentType = false; // tell jQuery not to set contentType
options.xhr = options.xhr ? options.xhr : function () {
//这是关键 获取原生的xhr对象 做以前做的所有事情
var xhr = $.ajaxSettings.xhr();
xhr.upload.onload = function () {
console.log("onload");
}
xhr.upload.onprogress = function (ev) {
if (ev.lengthComputable) {
var percent = 100 * ev.loaded / ev.total;
console.log(percent, ev)
}
}
return xhr;
};
options.success = options.success ? options.success : function (data) {
alert(data)
};
$.ajax(options);
}
//调用
$("#sub").click(function (e) {
AjaxForm("#myForm");
});

上述所述是俺给我们介绍的Ajax表单异步上传文件实例代码(包罗文件域),希望对我们有所援救,若是大家有其它疑问请给自家留言,我会及时回复我们的。在此也特别多谢大家对帮客之家网址的支撑!

http://www.bkjia.com/AJaxjc/1154501.htmlwww.bkjia.comtruehttp://www.bkjia.com/AJaxjc/1154501.htmlTechArticleAjax表单异步上传文件实例代码(包括文件域),ajax上传文件
一.起因
做前台页面时,要求调用WebAPI的Post请求,发送一些字段和文件(也便是…

做前台页面时,必要调用WebAPI的Post请求,发送一些字段和文件(也就是把表单通过ajax异步发送出去,得到再次来到结果),然后拿走重临值推断是或不是成功。

2.尝试

首先尝试了一晃 “jQuery Form Plugin”
,这厮便是的高大的坑,完结他和jquery1.九.2包容性就不是太好,好不轻巧把$.browser的主题材料解决了,开采用他上传文件得不到重回值。

$("#view").submit(
$("#view").ajaxSubmit({
type: "post",
url: "../api/Article/Add",
dataType: "json",
success: function (msg) {
console.log(msg);
},
error: function (msg) {
$("#resultBox").html("连接服务器失败");
console.log(msg);
}
})
);

诸如上边的代码,可是怎么安顿,只要上传了文件,success里面重回的msg一定是null(chromium浏览器下),但事实上是有再次来到值的,而且未有公文时也是正规的。更吓人的是IE/EDGE下提醒下载这一个Json重临值。

翻了须臾间jquery.form.js的源代码,开采他是用Iframe达成的伪Ajax,不清真,Pass!

// are there files to upload?
var files = $('input:file', this).fieldValue();
var found = false;
for (var j=0; j < files.length; j++)
if (files[j]) 
found = true;
if (options.iframe || found) // options.iframe allows user to force iframe mode
fileUpload();
else
$.ajax(options);

那是有无文件时,分别调用三个分化的函数。

三.消除方案

由此多反考查,开掘xhr(XMLHttpRequest)是个好东西。经过测试主流浏览器和手提式有线电话机浏览器都支持那么些东西。上边介绍一下在jquery/zepto的ajax
获取原生XMLHttpRequest
对象上传表单(文件)的法子。参照小说://www.jb51.net/article/91267.htm

function AjaxForm(formID, options) {
var form = $(formID);
//将form对象直接作为参数 new FormData对象
var formData = new FormData(form[0]);
$("input[type='file']").forEach(function (item, i) {
//获取file对象 即相当于可以直接post的$_FILES数据
var domFile = $(item)[0].files[0];
//追加file 对象
formData.append('file', domFile);
})
if (!options)options = {};
options.url = options.url ? options.url : form.attr("action");
options.type = options.type ? options.type : form.attr("method");
options.data = formData;
options.processData = false; // tell jQuery not to process the data
options.contentType = false; // tell jQuery not to set contentType
options.xhr = options.xhr ? options.xhr : function () {
//这是关键 获取原生的xhr对象 做以前做的所有事情
var xhr = $.ajaxSettings.xhr();
xhr.upload.onload = function () {
console.log("onload");
}
xhr.upload.onprogress = function (ev) {
if (ev.lengthComputable) {
var percent = 100 * ev.loaded / ev.total;
console.log(percent, ev)
}
}
return xhr;
};
options.success = options.success ? options.success : function (data) {
alert(data)
};
$.ajax(options);
}
//调用
$("#sub").click(function (e) {
AjaxForm("#myForm");
});

上述所述是作者给咱们介绍的Ajax表单异步上传文件实例代码(包括文件域),希望对大家有所支持,要是我们有别的疑问请给自家留言,作者会及时还原大家的。在此也特别多谢我们对剧本之家网址的支撑!

你可能感兴趣的篇章:

相关文章

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图