小谢第7问:js前端如何实现大文件分片上传、上传进度、终止上传以及删除服务器文件?
文件上传一般有两种方式:文件流上传和base64方式上传,毫无疑问,当进行大文件上传时候,转为base64是不现实的,因此用formData方式结合文件流,直接上传到服务器
本文主要结合vue的来讲解,主要知识点有“promise函数、formData对象使用、ajax异步上传、文件切割
//1、这里先在vue的Data中定义几个上传所需要的变量
taskId: '' //区分分包文件名
bytesPerPiece: 1 * 1024 * 1024, // 每个文件切片大小定为1MB .
totalPieces: 0,//文件切片个数
blob: '',//原始文件
start: 0,//第一个分片
end: 0,//最后一个分片
index: 1,//分片次序
filesize: 0,//文件大小
chunk: 0,//文件分片
formData: new FormData(),//后端header所需对象
// 2、分片上传方法--这里的ajax如果项目封装了axios可以直接改为axios,以避免使用jquery,使项目体积增大
fileSlice(){
return new Promise((resolve, reject) => {
var _this = this;
if (this.start < this.filesize) { //判断剩余文件大小,大于起始值执行切割操作
this.end = this.start + this.bytesPerPiece; //规定分片文件节点
if (this.end > this.filesize) { //判断是否是最后一个切片
this.end = this.filesize;
}
this.chunk = this.blob.slice(this.start, this.end); //切割文件
this.sliceIndex = this.index;
this.percentage = parseInt((this.sliceIndex / this.totalPieces) * 100); // 进度提示,如果不需要进度可省略
if(this.percentage == 0){ // 这里是因为当文件过大时候,避免进度显示过慢,影响用户体验
this.percentage = 1;
}
console.log('sliceIndex', this.sliceIndex, 'this.percentage', this.percentage);
this.formData = new FormData();
this.formData.append('file', this.chunk);
$.ajax({
type: 'post',
url: //后端接口
headers: { //后端所需参数
'jwt-token': Auth.getJwtToken(),
taskId: _this.taskId,
chunk: _this.sliceIndex,
size: _this.chunk.size,
chunkTotal: _this.totalPieces,
orginFileName: 'uploadFile'
},
//传入组装的参数
data: this.formData,
dataType: 'json',
async: true,
cache: false, //上传文件不需要缓存
contentType: false, //需设置为false。因为是FormData对象,且已经声明了属性enctype="multipart/form-data"
processData: false, //需设置为false。因为data值是FormData对象,不需要对数据做处理
success: function(res) {
if (_this.sliceIndex == _this.totalPieces) { //判断是否为最后一个文件,如果是,赋值后端输出路径 像服务端上传文件
_this.upPath = res.data.path;
_this.buttonLoading = false;
}
if(res.code == 0){
resolve('0');
}else{
_this.clearUploadFile();
reject(res.message);
}
},
error: function(res) { //异常判断
reject('上传文件失败,请重新上传!', this.fileList = []);
_this.$message({
message: res.message,
type: 'error'
});
return 'break';
}
});
}
_this.start = this.end;
_this.index++;
});
},
async fileUpload(file) { //此处主要给文件加32位随机数
console.log(file.file);
this.blob = file.file;
this.filesize = this.blob.size;
this.totalPieces = Math.ceil(this.filesize / this.bytesPerPiece);
function randomWord(randomFlag, min, max) {
// eslint-disable-next-line one-var
let str = '',
range = min,
arr = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd',
'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's',
't', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G',
'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U',
'V', 'W', 'X', 'Y', 'Z'
];
// 随机产生
if (randomFlag) {
range = Math.round(Math.random() * (max - min)) + min;
}
for (var i = 0; i < range; i++) {
let pos = Math.round(Math.random() * (arr.length - 1));
str += arr[pos];
}
return str;
} this.taskId = randomWord(false, 32); for(let i = 0; i < this.totalPieces; i++){
let ttt = await this.fileSlice().catch((res) => {
this.$message({
message: res,
type: 'error'
});
});
if(ttt != 0){
break;
}
}
},
//3、中止文件上传
clearUploadFile(){
// buttonLoading
this.buttonLoading = false;
this.totalPieces = 0;
this.blob = '';
this.start = 0;
this.end = 0;
this.index = 1;
this.filesize = 0;
this.chunk = 0; this.percentage = 0;
// 清空文件表
this.fileList = [];
const mainImg = this.$refs.upload;
if (mainImg && mainImg.length) {
mainImg.forEach(item => {
// item.uploadFiles.length = 0;
item.clearFiles();
});
}
},
小谢第7问:js前端如何实现大文件分片上传、上传进度、终止上传以及删除服务器文件?的更多相关文章
- 小谢第10问:前端JS下载文件、表格
对于小型文件及表格下载,一般采用a标签形式 <buttonb @click="downloadTemplate()">模板下载</button> downl ...
- 小谢第6问:js中,filter函数是怎么使用的
数组的常用方法filter,今天在做数组筛选的时候用到需要将有重复的数组去除,因此用到这个函数,主要用到-- 选择需要的属性,最终留下想要的数组,如果刚开始的话可以看下下面代码 let nums = ...
- 小谢第23问: chorme的性能优化工具
问题场景:在前端日趋工程化的今天,前端性能优化是一名合格的前端工程师必备的技能,那么,如何正确的使用性能分析工具呢? 解决方案: 性能分析的流程: 在开发中我一般使用公司开发的测试脚本-kbase-w ...
- 小谢第37问:关于websocket推送进度,本地保存进度条,然后跳出页面进入后再显示的问题
1.主要技术点:sessionStorage 会话存储进度 这里在使用之前,顺便说一下cookie.sessionStorage.localStorage 共同点:都是保存在浏览器端,且同源的. 区别 ...
- 小谢第50问:vuex的五个属性-使用-介绍
一.Vuex 是什么? 官网:Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式.它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化. 关键词:状态 ...
- 小谢第58问:nuxt搭建企业官网
最近公司要重构公司官网,jq+bootstrap 改为了vue,刚开始我以为用vue不是挺好的嘛,后来才发现,有于vue单页面的特性,不利于搜索引擎的抓取,因此在seo方面需要另外想办法,于是乎,就找 ...
- 小谢第8问:ui框架的css样式如何更改
目前有三种方法, 1.使用scss,增加样式覆盖,但是此种方法要求css的className需要与框架内的元素相一致,因此修改时候需要特别注意,一个父级的不同就可能修改失败 2.deep穿透,这种方法 ...
- 小谢第2问:后端返回为数组list时候,怎么实现转为tree
要求后端返回给我的list时候,在数组中定义有id , parentid, 可以用双重循环的方法,得到tree需要的数据结构,这样得到的数据就可以直接复制给树组件的data啦const oldData ...
- 小谢第1问:为什么要写blog
一直犹豫了好久,终于在csdn上弄好了自己的博客账号,感谢平台,以后在工作的过程中,遇到不懂得问题,解决后,会在这里记录下自己所遇到的问题
随机推荐
- SSTI(服务器模板注入)学习
SSTI(服务器模板注入)学习 0x01 SSTI概念 SSTI看到ss两个字母就会想到服务器,常见的还有SSRF(服务器端请求伪造).SSTI就是服务器端模板注入(Server-Side Templ ...
- spring的后台数据校验
数据校验对于开发项目来说是必须的.校验一般分为前台校验和后台校验,前台校验是必须要做的,后台校验是可选的.后台校验相对前台校验来说配置起来一般更复杂.前台校验通过js做,前台校验一般非常容易绕过.sp ...
- 基于胜率矩阵的PageRank排序
在做博弈模型评估的时候,遇到一个问题是如何评价多个模型的优劣.例如我有训练好的三个围棋模型A,B,C,两两之间对打之后有一个胜负关系,如何对这三个模型进行排序呢?通常对于人类选手这种水平有波动的情 ...
- 自己动手写RPC
接下来2个月 给自己定个目标 年前 自己动手做个RPC 框架 暂时技术选型 是 dotcore + netty + zookeeper/Consul
- 老板:kill -9 的原理都不知道就敢去线上执行?明天不用来了!
GitHub 14.5k Star 的Java工程师成神之路,开放阅读了! 相信很多程序员对于Linux系统都不陌生,即使自己的日常开发机器不是Linux,那么线上服务器也大部分都是的,所以,掌握常用 ...
- 设计模式GOF23之单例模式
单例模式的五种方式 主要:懒汉式,饿汉式 其他:双重检测锁(Double Checking模式),静态内部类,枚举模式 选取时机 延时加载,占用内部资源大:静态内部类好于懒汉 不延时加载,占用内部资源 ...
- USACO 3.1 Contact
http://www.nocow.cn/index.php/Translate:USACO/contact 题目大意:给一个只含0和1的序列,统计每个子序列的重复次数,并按次数递减来输出 考虑子序列时 ...
- javascript实现checkbox提交submit请求
javascript实现checkbox提交submit请求 背景:使用django模板中for来形成多个checkbox,需要点击单个checkbox并查询数据触发submit请求到后台,djang ...
- 解决:idea中右键项目找不到subversion
2019.02版IDEA,刚刚发现更新不了项目,但是我记得之前的项目是可以直接更新的.然后,我打开之前的项目找到相关项,对比了一下,找到了方法: file--settings--Version Con ...
- 【5min+】美化API,包装AspNetCore的返回结果
系列介绍 [五分钟的dotnet]是一个利用您的碎片化时间来学习和丰富.net知识的博文系列.它所包含了.net体系中可能会涉及到的方方面面,比如C#的小细节,AspnetCore,微服务中的.net ...