jQuery实现input[type=file]多图预览上传删除等功能
下⾯我们了解⼀下,多图上传时,怎么实现预览、上传、删除等功能。下图是功能实现的预览效果,虽然样式有点丑,不过功能还是实现了。话不多说,直接看代码会更直观⼀些。
⾸先定义⼀下基本格式,样式代码⾃⾏脑补:
<body>
<div class="upload-header">
<input id="upload" type="file" accept="image/*" multiple="multiple">
<button class="btn">点击上传</button>
</div>
<div class="img-box">
<!-- 存放预览图⽚ -->
</div>
</body>
接着定义看⼀下具体的js实现代码,我是基于JQ做的开发,⽅便DOM的操作。
1. 预览功能的实现
这⾥监听input[type=file]的change事件,在回调函数中,取到暂存区的⽂件e.target.files,通过遍历files ⽂件属性,使⽤FileReader 函数读取⽂件的值,然后使⽤append⽅法把图⽚放⼊指定盒⼦中。备注::FileReader是⼀种异步⽂件读取机制,结合input:file可以很⽅便的读取本地⽂件。
imgPreview: function () {
matlab画椭圆var that = this;
$('.upload-header').on('change', '#upload', function(e) {
var files = e.target.files;
if (files.length > 0) {
for (var i = 0; i < files.length; i++) {
var reader = new FileReader();
shell脚本实现菜单var text = `
<div class="img-list">
<img src="${sult}" alt="">
<div class="del-img">删除</div>
</div>jquery下载超大文件
`
$('.img-box').append(text);
};
that.filesList.push(files[i]);
};
};
})
}
2. 图⽚删除功能
这⾥是使⽤on⽅法对预览的图⽚添加点击事件,这⾥使⽤on⽅法主要是因为on⽅法对后⾯添加的dom可以继续监听。当需要删除照⽚时,直接删除其图⽚的⽗节点及以下节点就可以了。此时记得把暂存区的⽂件filesList也要对应删除。
delImage: function () {
var that = this;
$('.img-box').on('click', '.del-img', function () {
var delStatus = confirm('确认这张图⽚删除吗?');
免费的xml编辑器if (delStatus) {
var index = $(this).parent().index();
$(this).parent().remove();
that.filesList.splice(index, 1);
console.log('我删除啦', index);
};
});
}
2. 图⽚批量上传功能
图⽚上传我定义了两个⽅法,第⼀⽅法是点击上传后,对所有⽂件进⾏遍历,依次调取上传的⽅法(因为⽤的七⽜上传⼯具,只⽀持单个⽂件上传,所以采取了遍历的⽅式)。第⼆个⽅法使⽤了jq的ajax的post上传⽅式,使⽤FormData实例,添加file 属性进⾏上传。因为是批量上传,所以我使⽤了定义临时变量flag 的⽅式来判断⽂件是否都上传完成,当flag的值与filesList的数量⼀致时,就可以判断所有上传完成。使⽤⽅法⽐较low,如果其他好的⽅法可以留⾔交流。
clickUpload: function () {
var that = this;
var filesList = this.filesList;
$('.btn').on('click', function() {
that.flag = 0;
if (filesList.length > 0) {
for (var i = 0; i < filesList.length; i++) {
that.upLoadMethod(filesList[i]);
}
};
})
},
upLoadMethod: function (file) {
var that = this;
var formData = new FormData();
formData.append('file', file);
$.ajax({
type: "post",
url: '172.16.1.99:8703/file/upload',
data: formData,
mimeType: "multipart/form-data",
dataType: "json",
async: false,
cache: false, //上传⽂件不需要缓存
contentType: false, //需设置为false。因为是FormData对象,且已经声明了属性enctype="multipart/form-data"
processData: false, //需设置为false。因为data值是FormData对象,不需要对数据做处理
success: function (response) {
that.flag += 1;
if (that.flag === that.filesList.length) {
console.log('我上传完成了');
};
},
error: function (err) {
console.log('上传失败');
}
});
},
以下是完整的js代码,供参考:
<script>
function UploadFunction (name) {
this.name = name;
this.init();
};
UploadFunction.prototype = {
/
/ 初始化
init: function () {
this.clickUpload();
this.imgPreview();
this.delImage();
},
flag: 0,
filesList: [],
// 点击上传
clickUpload: function () {
var that = this;
var filesList = this.filesList;
$('.btn').on('click', function() {
that.flag = 0;
if (filesList.length > 0) {
for (var i = 0; i < filesList.length; i++) {
that.upLoadMethod(filesList[i]);
}
};
})
},
imgPreview: function () {
mysql备份表
var that = this;
$('.upload-header').on('change', '#upload', function(e) {
var files = e.target.files;
console.log(files);
if (files.length > 0) {
for (var i = 0; i < files.length; i++) {
var reader = new FileReader();
var text = `
<div class="img-list">
<img src="${sult}" alt="">
<div class="del-img">删除</div>
</div>
`
$('.img-box').append(text);
简单制表步骤视频教程};
that.filesList.push(files[i]);
};
};
})
},
upLoadMethod: function (file) {
var that = this;
var formData = new FormData();
formData.append('file', file);
$.ajax({
type: "post",
url: '这⾥使⽤上传的地址/upload',
data: formData,
mimeType: "multipart/form-data",
dataType: "json",
async: false,
cache: false, //上传⽂件不需要缓存
contentType: false, //需设置为false。因为是FormData对象,且已经声明了属性enctype="multipart/form-data" processData: false, //需设置为false。因为data值是FormData对象,不需要对数据做处理
success: function (response) {
that.flag += 1;
if (that.flag === that.filesList.length) {
console.log('我上传完成了');
};
},
error: function (err) {
console.log('上传失败');
}
});
},
delImage: function () {
var that = this;
$('.img-box').on('click', '.del-img', function () {
var delStatus = confirm('确认这张图⽚删除吗?');
if (delStatus) {
var index = $(this).parent().index();
$(this).parent().remove();
that.filesList.splice(index, 1);
console.log('我删除啦', index);
};
});
}
}
var UploadFunction = new UploadFunction('⼩明删照⽚');
总结
以上所述是⼩编给⼤家介绍的jQuery实现input[type=file]多图预览上传删除等功能,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
如果你觉得本⽂对你有帮助,欢迎转载,烦请注明出处,谢谢!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论