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 () {

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();

reader.onload = function () {

var text = `

<div class="img-list">

<img src="${this.result}" alt="">

<div class="del-img">删除</div>

</div>

`

$('.img-box').append(text);

};

reader.readAsDataURL(files[i]);

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('确认这张图片删除吗?');

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: 'http://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 () {

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();

reader.onload = function () {

var text = `

<div class="img-list">

<img src="${this.result}" alt="">

<div class="del-img">删除</div>

</div>

`

$('.img-box').append(text);

};

reader.readAsDataURL(files[i]);

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]多图预览上传删除等功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

以上是 jQuery实现input[type=file]多图预览上传删除等功能 的全部内容, 来源链接: utcz.com/z/360050.html

回到顶部