jQuery实现input[type=file]多图预览上传删除等功能
前端  /  管理员 发布于 4年前   839
下面我们了解一下,多图上传时,怎么实现预览、上传、删除等功能。下图是功能实现的预览效果,虽然样式有点丑,不过功能还是实现了。话不多说,直接看代码会更直观一些。
首先定义一下基本格式,样式代码自行脑补:
Top接着定义看一下具体的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 = `
删除 ` $('.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代码,供参考:
- 相关文章
- 使用 Alpine.js 排序插件对元素进行排序(0个评论)
- 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
- 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
- 使用mock-server实现模拟接口对接流程步骤(0个评论)
- vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
- 近期文章
- 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
- 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
- gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
- 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
- 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
- Laravel从Accel获得5700万美元A轮融资(0个评论)
- 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
- 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
- PHP 8.4 Alpha 1现已发布!(0个评论)
- Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
- 近期评论
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号