H5利用formData来上传文件(包括图片,doc,pdf等各种格式)方法小结!
H5页面中我们常需要进行文件上传,那么怎么来实现这个功能呢??? 我主要谈如下两种方法。
(一)、传统的form表单方法
<form action="/Home/SaveFile1" method="post" enctype="multipart/form-data">
<input type="file" class="file1" name="file1" multiple id="file" />
<button type="submit" class="but1">上传</button>
</form> <script>
document.getElementById("file").onchange = function () {
let filesContent = document.getElementById("file").files;
console.log(filesContent);
}
</script>
这个目前大概了解一下就ok了,反正就需要form 标签,需要配置 method="post" enctype="multipart/form-data" 需要给input 加name= "" 属性。
这个方法相对比较落后了,目前不推荐这么操作,请看第二种方法。
(二)、利用FormData来实现相关的功能
1、html部分按照如下写法(vue写法)即可,当然,样式问题可以根据自己的想法把上传上去的文件样式进行优化。发现没有,这里不需要写name属性,因为后续的new formData 里面的键就代表name
<input
type="file"
class="upload"
@change="addImg" // 监听input的改变,改变即可获取上传的文件内容。
ref="inputer"
accept="image/*" // 代表限制上传的格式,这里表示限制为图片,其他格式参照网上其他说明
multiple // 代表可以上传多个文件,去掉则不可一下子多图上传
/>
展示上传文件的大概html格式
<div class="uploadBox" v-for="(value, key) in imgs" :key="key">
<img :src="getObjectURL(value)" alt class="uploadImg" />
<img src="../../assets/images/close.png" alt class="closeImg" @click="delImg(key)" />
</div>
2、js 部分如下:
data() {
return {
formData: new FormData(),
imgs: {}, 这个是用来保存所有的上传内容,对象格式,键值对格式
imgLen: 0,
};
},
addImg() { // 监听了input的改变
let that = this;
let inputDOM = this.$refs.inputer; // 获取input的dom元素
this.fil = inputDOM.files; // 获取dom元素对应的files内容,注意files的内容为js对象格式,即key,value,我们真正需要的文件内容为value.
for (let i = 0; i < this.fil.length; i++) { //遍历files 然后判断上传的每个文件大小,如果不符合要求则返回
let size = Math.floor(this.fil[i].size / 1024);
if (size > 5 * 1024 * 1024) {
that.$toast({
message: "请输入5M以内的文件",
position: "middle",
duration: 1500
});
return false;
}
this.imgLen++;
this.$set( // 对于符合要求的文件则push进imgs对象中,这里给文件对象的key通过时间戳进行改名,当然这里不改也可以。
this.imgs,
this.fil[i].name + "?" + new Date().getTime() + i,
this.fil[i]
); // 至此我们就把累积的上传的文件都放在了imgs对象中,相当于我们不直接用files对象,而是经过自己处理,得出的一个新的imgs对象。
}
},
delImg(key) { // 这个是用来把展示的文件进一步删除后的操作。
this.$delete(this.imgs, key);
this.imgLen--;
},
getObjectURL(file) {
var url = null;
if (window.createObjectURL != undefined) {
url = window.createObjectURL(file);
} else if (window.URL != undefined) {
url = window.URL.createObjectURL(file);
} else if (window.webkitURL != undefined) {
url = window.webkitURL.createObjectURL(file);
}
return url;
},
传完毕文件并展示出来后,那么我们就需要进行正式上传了,如下便是js真正提交的方法。
ajax方法上传一张图片及多张图片的方法:
submit() {
let that = this;
// 单张图的方法
for (let key in this.imgs) { //即使上传一张图片也得进行循环,要么无法拿到value的值。
this.formData.append('filename', this.imgs[key]); // 注意这里的filename 和input 直接写name = "filename" 是等价的!!!也就是这个名字需要和后台进行约定!!!
}
// 多张图的方法
this.formData.append('id', that.id); // formdata不仅可以传文件,也可以顺便传点普通的值!!!下同
this.formData.append('uid', that.uid);
this.formData.append('content', that.desc);
mui.showLoading("图片上传中..","div");
$.ajax({
url: api_url + '/api2_1/TaskApply/tkAdd2',
type: 'POST',
cache: false, //上传文件不需要缓存
data: this.formData,
processData: false, // 告诉jQuery不要去处理发送的数据
contentType: false, // 告诉jQuery不要去设置Content-Type请求头
success: function (res) {
console.log(res)
if (res.code == 200) {
mui.hideLoading();
window.location.href = "index.html";
} else if (res.code == 401) {
mui.toast("图片不能为空", {
duration: 'short',
type: 'div'
});
}
},
error: function (data) {
console.log(data)
}
})
},
axios 上传图片的方法
let config = {
headers: { "Content-Type": "multipart/form-data" }
};
console.log(that.imgs);
for (let key in that.imgs) {
that.formData.append("filename[]", that.imgs[key]);
}
that.$post("/Recruit/uploadfile", that.formData, config).then((res)=>{
})
完毕!!!
尤其需要注意多图上传的写法。
H5利用formData来上传文件(包括图片,doc,pdf等各种格式)方法小结!的更多相关文章
- 利用formdata对象上传文件时,需要添加的参数
function doUpload() { var formData = new FormData($( "#uploadForm" )[0]); $.ajax({ url: 'h ...
- 使用FormData上传文件、图片
关于FormData XMLHttpRequest Level 2添加了一个新的接口 ---- FormData 利用FormData对象,可以通过js用一些键值对来模拟一系列表单控件,可以使用XM ...
- 通过jQuery Ajax使用FormData对象上传文件
FormData对象,是可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单". 在 Mozilla Developer 网站 使用For ...
- IT轮子系列(四)——使用Jquery+formdata对象 上传 文件
前言 在MVC 中文件的上传,一般都采用控件: <h2>IT轮子四——文件上传</h2> <div> <input type="file" ...
- 通过jQuery Ajax使用FormData对象上传文件 (转载)
XMLHttpRequest Level 2 添加了一个新的接口——FormData.与普通的 Ajax 相比,使用 FormData 的最大优点就是我们可以异步上传二进制文件.jQuery 2.0+ ...
- [转] 通过jQuery Ajax使用FormData对象上传文件
FormData对象,是可以使用一系列的键值对来模拟一个完整的表单,然后使用XMLHttpRequest发送这个"表单". 在 Mozilla Developer 网站 使用For ...
- python中使用multipart/form-data请求上传文件
最近测试的接口是上传文件的接口,上传单个文件,我主要使用了2种方法~ 接口例如: URL: http://www.baidu.com/*** method:post 参数: { "salar ...
- 使用python或robotframework调multipart/form-data接口上传文件
这几天调一个multipart/form-data类型的接口,遇到点小阻碍.之前同事有使用urllib库写了个类似的方法实现,比较长,想要改的时候发现不太好使.在网上查找发现用requests库做这个 ...
- Webform之FileUpload(上传按钮控件)简单介绍及下载、上传文件时图片预览
1.FileUpload上传控件:(原文:http://www.cnblogs.com/hide0511/archive/2006/09/24/513201.html) FileUpload 控件显示 ...
随机推荐
- 关于nslookup以及dig命令的研究报告
我们在日常上网时都是用域名访问网路,如www.baidu.com,而在实际寻址过程中,是使用IP地址,如180.101.49.11,域名到IP地址的解析是通过DNS服务器来实现的,系统中我们可以用一些 ...
- linux安装mysql后报错启动不了Starting MySQL. ERROR! The server quit without updating PID file (/var/lib/mysql/localhost.localdomain.pid).
今天安装完Mysql后,开启发生了错误: 2.打开错误信息文件,查看错误原因是:Plugin 'FEDERATED' is disabled. /usr/sbin/mysqld: Table 'mys ...
- 又一个秘密如何让浏览器访问最新的js,css等外部引用
在引用文件末尾加上一个参数,让浏览器知道这个文件跟上一个文件是不同的,让浏览器去服务器重新加载最新的,例如:<script type="text/javascript" sr ...
- js模块基础练习题
题目描述 完成函数 createModule,调用之后满足如下要求: 1.返回一个对象 2.对象的 greeting 属性值等于 str1, name 属性值等于 str2 3.对象存在一个 sayI ...
- 笔记本端查看以前的wifi密码
家里老人忘记密码了.好像是我改了从,我也忘了,手中安卓手机root后也没找到记录密码的文件,水果机懒得弄了,突然想起来电脑还有记录,应该可以找到. 此篇也顺带记录下怎么通过手中笔记本找到以前练过的wi ...
- django中使用AJAX时如何获取表单参数(按钮携带参数)
前提是函数和相应的视图路由都已经配置好了,然后就是表单了: <form id="SmsForm" method="post" class="a& ...
- 使用jquery.datatable.js注意事项
本文链接:https://blog.csdn.net/ylg01/article/details/76463908写在最前面的话,如果不是维护老项目或者在老项目上二次开发尽量不要用这个表格插件 为什么 ...
- 【Mybatis异常】Caused by: java.sql.SQLException: Parameter index out of range (1 > number of parameters, which is 0).
一.错误原因分析 从错误提示可以看出:实际传入的参数大于sql中待设置的参数,也就是sql中的?少于参数或?根本没有产生原因: ?号被单引号包围 如: sql += " and artic ...
- HotSpot虚拟机的锁优化
面试中多次被问到synchronized关键字的实现原理,一直认为仅是monitorenter与monitorexit两条指令而已,原来底层涉及到多种锁优化策略,包括:自旋锁,轻量锁,偏向锁. 1.自 ...
- centos安装zookeeper,并集群配置
所有机器操作都一样! 注:zookeeper配置集群时 需把防火墙关掉 或者暴露配置文件里配置的端口, 并且在dataDir目录下要有myid文件 1 下载 wget https://mirrors. ...