下面我们了解一下,多图上传时,怎么实现预览、上传、删除等功能。下图是功能实现的预览效果,虽然样式有点丑,不过功能还是实现了。话不多说,直接看代码会更直观一些。
首先定义一下基本格式,样式代码自行脑补:
<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]多图预览上传删除等功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
本文向大家介绍input file上传 图片预览功能实例代码,包括了input file上传 图片预览功能实例代码的使用技巧和注意事项,需要的朋友参考一下 input file上传图片预览其实很简单,只是没做过的感觉很神奇,今天我就扒下她神秘的面纱,其实原理真的很简单,下面通过一段代码大家都明白了。 具体代码如下所示: 实现上传图片直接预览,避免提交后在读取图片的冗余过程 以上所述是小编给大家介绍
本文向大家介绍javascript实现input file上传图片预览效果,包括了javascript实现input file上传图片预览效果的使用技巧和注意事项,需要的朋友参考一下 本文实例介绍了javascript实现input file上传图片预览效果的详细代码,分享给大家供大家参考,具体内容如下 运行效果图: 具体实现代码: 希望本文所述对大家学习javascript程序设计有所帮助。
本文向大家介绍上传图片预览JS脚本 Input file图片预览的实现示例,包括了上传图片预览JS脚本 Input file图片预览的实现示例的使用技巧和注意事项,需要的朋友参考一下 在深圳做项目的时候,需要一个用户上传头像预览的功能!是在网上找了好多,都不太满意。要么是flash的,要么是Ajax上传后返回图片路径的,要么压根就是不能用的。幸运的是在这个项目以前有人写过一个图片预览的功能,还被我
本文向大家介绍jQuery实现本地预览上传图片功能,包括了jQuery实现本地预览上传图片功能的使用技巧和注意事项,需要的朋友参考一下 本文实例介绍了基于JQUERY扩展,图片上传预览插件,目前兼容浏览器(IE 谷歌 火狐) 不支持safari,分享给大家供大家参考,具体内容如下 HTML代码: js代码: 直接上第二段代码,jquery js实现上传图片之前预览本地图片 以上就是本文的全部内容,
本文向大家介绍Nodejs实现图片上传、压缩预览、定时删除功能,包括了Nodejs实现图片上传、压缩预览、定时删除功能的使用技巧和注意事项,需要的朋友参考一下 前言 我们程序员日常都会用到图片压缩,面对这么常用的功能,肯定要尝试实现一番。 第一步,node基本配置 这里我们用到的是koa框架,它可是继express框架之后又一个更富有表现力、更健壮的web框架。 1、引入基本配置 2、使用基本配置
本文向大家介绍input type=file 选择图片并且实现预览效果的实例,包括了input type=file 选择图片并且实现预览效果的实例的使用技巧和注意事项,需要的朋友参考一下 通过<input />标签,给它指定type类型为file,可提供文件上传; accept:可选择上传类型,如:只要传图片,且不限制图片格式,为image/*; multiple:规定是否可以选择多个文件; 规定