本文介绍: 这种写法可以省略很多html代码,使得页面结构在编码时显得简单易懂,大部分工作都交由javascript来完成,尤其因为去掉了form标签,所以得使用javascript的FormData来手动构建表单对象,文件的二进制数据可以直接使用jQuery来获取到,然后再通过ajax提交到服务端即可。这种方式写form标签必须要有,并且必须要有action、method、和enctype属性,且entype属性值必须为multipart/form–data,这样后台才会认为这是一个二进制文件进行接收。
前端写法
<form action="/demo/upload2" method="POST" enctype="multipart/form-data">
<input id="file" type="file" name="mFile"/>
<input type="submit" value="上传"/>
</form>
这种方式写form标签必须要有,并且必须要有action、method、和enctype属性,且entype属性值必须为multipart/form–data,这样后台才会认为这是一个二进制文件进行接收。
2.直接使用javascript来获取html标签中文件的值
html:
<input id="file" type="file" name="mFile"/>
<input type="button" onclick="upload()" value="上传">
function upload() {
var formData = new FormData();
formData.append("mFile",$("#file")[0].files[0]);
$.ajax({
url: "/demo/upload2",
type: 'POST',
data: formData,
processData: false,
contentType:false,
success : function(data) {
console.log(data);
}
});
}
这种写法可以省略很多html代码,使得页面结构在编码时显得简单易懂,大部分工作都交由javascript来完成,尤其因为去掉了form标签,所以得使用javascript的FormData来手动构建表单对象,文件的二进制数据可以直接使用jQuery来获取到,然后再通过ajax提交到服务端即可。使用这种方法必须注意一下几点:
表单数据必须要由FormData来构建
processData必须为false,告诉jQuery不要对参数进行处理
contentType必须为false,告诉jQuery不要对contentType做处理,服务器会做处理
原文地址:https://blog.csdn.net/wpf_China/article/details/132732878
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_28582.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。