jQuery插件实现文件上传功能(支持拖拽)


Posted in Javascript onAugust 27, 2020

先贴上源代码地址,点击获取。然后直接进入主题啦,当然,如果你觉得我有哪里写的不对或者欠妥的地方,欢迎留言指出。在附上一些代码之前,我们还是先来了解下,上传文件的时候需要利用的一些必要的知识。

 首先我们要说的就是FileReader对象,这是一个HTML5提出的,专门用来异步的读取用户计算机上文件的对象,这里有详细的介绍。所以如果我们想要使用它,那么首先我们得先创建一个FileReader对象。
 var fr = new FileReader()

1、这个对象拥有五个方法:

jQuery插件实现文件上传功能(支持拖拽)

下面附上一个例子:

<input type="file" id="file"/>
 <img src="" alt="" id="img">
 <script src="jquery.min.js"></script>
 <script>
 var ipt = $('#file'),
 img = $('#img');
 ipt.change(function () {
 var fr = new FileReader();
 fr.readAsDataURL(this.files[0]);
 fr.onload = function () {
 img.attr('src', fr.result);
 }
 })
 </script>

效果图:

jQuery插件实现文件上传功能(支持拖拽)

其他的几个方法也基本上大同小异,所以在这里就不做过多解释了。

2、这个对象还拥有三个状态常量:

jQuery插件实现文件上传功能(支持拖拽)

3、这个对象还拥有三个属性:

jQuery插件实现文件上传功能(支持拖拽)

4、6个事件处理程序:

jQuery插件实现文件上传功能(支持拖拽)

这里我们再来说说formData对象,同样的我们利用它来上传文件,首先需要创建一个formData对象实例
var formData = new FormData();
这个对象有一个append方法,该方法接受三个参数:name、value、filename

jQuery插件实现文件上传功能(支持拖拽)

在使用这个对象上传文件的时候,我们需要注意一点,需要在form标签上添加上enctype="multipart/form-data"这个属性,用来设置表单的MIME编码,因为默认的编码格式是application /x-www-form-urlencoded,不能用于文件上传,也可以在使用jQuery的$.ajax方法的时候,设置data属性为formData。
 上面就是该DEMO主要用到的知识点,下面附上一些源代码,和效果图。

 HTML代码: 

<div class="up_load_file">
 </div>
 <script src="js/jquery-1.11.3.js"></script>
 <script src="js/uploadfile.js"></script>
 <script>
 $('.up_load_file').uploadfile({
 url : 'file.php',
 width : 500,
 height : 50,
 canDrag : true,
 canMultiple : true,
 success: function (fileName) {
 alert(fileName + '上传成功');
 },
 error: function (fileName) {
 alert(fileName + '上传失败');
 },
 complete : function () {
 alert('所有文件上传完毕');
 }
 });
 </script>

JS代码: 

;(function ($, undefined) {
 $.fn.uploadfile = function (setting) {
 var defaultSetting = {
 url : 'file.php',
 width : 600,
 height : 50,
 canDrag : true,
 canMultiple : true,
 success : function (fileName) { //单个文件上传成功的回调函数
 },
 error : function (fileName) { //单个文件上传失败的回调函数
 },
 complete : function () { //上传完成的回调函数
 }
 };

 //判断浏览器是否支持FileReader
 if(!window.FileReader){
 alert('您的浏览器不支持FileReader,请更换浏览器。');
 return;
 }

 setting = $.extend(true, {}, defaultSetting, setting);
 setting.width < 450 && (setting.width = 450);

 $(this).each(function (i, item) {
 var demoHtml = '';
 //是否可以拖拽图片上传,构造dom结构
 if(setting.canDrag){
 setting.height < 200 && (setting.height = 200);
 demoHtml += '<div class="file_sel">';
 demoHtml += '<div class="file_input">';
 demoHtml += '<div class="sel_file_img">';
 demoHtml += '<span><img src="img/add_img.png"/></span>';
 demoHtml += '</div>';
 demoHtml += '<div class="sel_file_btn">';
 demoHtml += '<input type="file"/>';
 demoHtml += '<button>点击选择文件</button>';
 demoHtml += '</div>';
 demoHtml += '</div>';
 demoHtml += '<div class="file_drag">';
 demoHtml += '<span>或者将文件拖到此处</span>';
 demoHtml += '</div>';
 demoHtml += '</div>';
 demoHtml += '<div class="file_info_handle">';
 demoHtml += '<div class="file_info">';
 demoHtml += '当前选择了<span class="file_count">0</span>个文件,共<span class="file_size">0</span>KB。';
 demoHtml += '<input type="file"/>';
 demoHtml += '<button class="continue_sel">继续选择</button>';
 demoHtml += '<button class="uploadfile">开始上传</button>';
 demoHtml += '</div>';
 demoHtml += '</div>';
 demoHtml += '<div class="file_show">';
 demoHtml += '</div>';
 }else{
 setting.height < 50 && (setting.height = 50);
 $(item).addClass('noDrag');
 demoHtml += '<div class="file_info_handle">';
 demoHtml += '<div class="file_info">';
 demoHtml += '当前选择了<span class="file_count">0</span>个文件,共<span class="file_size">0</span>KB。';
 demoHtml += '<input type="file"/>';
 demoHtml += '<button class="continue_sel">继续选择</button>';
 demoHtml += '<button class="uploadfile">开始上传</button>';
 demoHtml += '</div>';
 demoHtml += '</div>';
 demoHtml += '<div class="file_show">';
 demoHtml += '<div class="sel_file_btn">';
 demoHtml += '<input type="file"/>';
 demoHtml += '<div class="sel_btn"></div>';
 demoHtml += '</div>';
 demoHtml += '</div>';
 }
 $(item).css({
 width : setting.width,
 height : setting.height,
 display : 'block'
 });
 $(item).html(demoHtml);

 //获取DOM节点
 var fileArr = [],
 fileSize = 0,
 _this = $(item),
 fileDrag = $('.file_sel .file_drag', _this),
 selFileIpt = $('input[type=file]', _this),
 selFileBtn = selFileIpt.next();
 fileCount = $('.file_info_handle .file_info .file_count', _this),
 fileSz = $('.file_info_handle .file_info .file_size', _this),
 beginUpload = $('.file_info_handle .file_info .uploadfile', _this),
 fileShow = $('.file_show', _this),
 noDragSelFile = $('.file_show .sel_file_btn', _this);
 
 //显示拖拽上传部分
 setting.canDrag || fileShow.show();

 //是否可以多选
 setting.canMultiple && selFileIpt.attr('multiple', 'multiple');

 //绑定事件
 selFileIpt.on('change', selFile);

 //让按钮去触发input的click事件
 selFileBtn.on('click', function () { 
 $(this).prev().click();
 })

 fileDrag.on({
 dragover : dragOver, 
 drop : selFile
 })

 beginUpload.on('click', upLoadFile);

 

 // 选择文件
 function selFile (e) {
 e = e || window.event;
 //阻止浏览器的默认行为
 if(e.preventDefault){ 
 e.preventDefault(); 
 }else{
 e.returnValue = false;
 }
 var files = this.files || event.dataTransfer.files,
 src = 'img/',
 imgSrc;
 Array.prototype.forEach.call(files, function (item, i) {

 //防止重复选择相同的文件
 var notExist = fileArr.some(function (existFile) {
 return existFile.name === item.name;
 })
 if(notExist && fileArr.length != 0){
 return !notExist;
 }

 fileArr.push(item);
 var fr = new FileReader();
 fr.readAsDataURL(item);
 fr.onload = function () {

 //判断展示的文件类型
 if(item.type.indexOf("image") > -1){
 imgSrc = fr.result;
 }else if(item.name.indexOf("rar") > -1){
 imgSrc = src + 'rar.png';
 }else if(item.name.indexOf("zip") > -1){
 imgSrc = src + 'zip.png';
 }else if(item.type.indexOf("text") > -1){
 imgSrc = src + 'txt.png';
 }else{
 imgSrc = src + 'file.png';
 }

 //展示选择的文件
 var imgDom = $('<span class="img_box"><span class="up_load_success" title="上传成功"></span><span class="img_handle"><span class="file_name" title="'+ item.name +'">'+ item.name +'</span><span class="icon-bin"></span></span><img src="'+ imgSrc +'"/></span>');
 if(setting.canDrag){
 fileShow.css('display') === 'none' && fileShow.show();
 fileShow.append(imgDom);
 }else{
 fileShow.css('display') === 'none' && fileShow.show();
 noDragSelFile.before(imgDom);
 }
 }
 })

 //选择的文件的信息
 fileCount.html(fileArr.length);
 fileSz.html(getFileInfo());

 //防止在删除了上次选择的文件后,再次选择相同的文件无效的问题。
 this.value =''; 
 }

 //拖拽
 function dragOver (e) {
 var event = e || window.event;
 event.preventDefault();
 }

 //上传文件
 function upLoadFile () {
 if(!fileArr.length){
 alert('请选择文件');
 return;
 }
 fileArr.forEach(function (item, i) {
 var upLoadSuccess = $('.img_box').eq(i).children('.up_load_success');
 
 //防止重复上传
 if(upLoadSuccess.css('display') === 'block') return false; 
 var formData = new FormData();
 formData.append('file', item);
 $.ajax({
 url: setting.url,
 type: 'POST',
 cache: false,
 data: formData,
 processData: false,
 contentType: false
 }).done(function(res) {
 //上传成功图标
 upLoadSuccess.show();

 //单个文件上传成功执行回调
 setting.success(item.name);

 //全部文件上传完成执行回调函数
 (i === (fileArr.length - 1)) && setting.complete();
 }).fail(function(res) {
 //单个文件上传失败执行回调
 setting.error(item.name);

 (i === (fileArr.length - 1)) && setting.complete();
 });
 })
 }

 //计算文件信息
 function getFileInfo () {
 //每次重新计算大小,防止单位不同造成错误
 fileSize = 0;
 fileArr.forEach(function (item, i) {
 fileSize += item.size;
 })
 fileSize = (fileSize / 1024).toFixed(2);
 return fileSize;
 }

 fileShow.on('click', '.icon-bin' , function () {
 //删除节点
 var index = $(this).parents('.img_box').index();
 $(this).parents('.img_box').remove();

 //删除上传文件
 fileArr.splice(index, 1);

 //修改文件信息
 fileCount.html(fileArr.length);
 fileSz.html(getFileInfo());

 //隐藏文件显示区域
 !setting.canDrag || fileArr.length || fileShow.hide();
 })
 })
 }
})(jQuery)

后台PHP代码: 

$fileName = $_FILES['file']['name'];
 $type = $_FILES['file']['type'];
 $size = $_FILES['file']['size'];
 $fileAlias = $_FILES["file"]["tmp_name"];

 if($fileAlias){
 move_uploaded_file($fileAlias, "uploadfile/" . $fileName);
 }
 echo 'fileName: ' . $fileName . ', fileType: ' . $type . ', fileSize: ' . ($size / 1024) . 'KB';

支持拖拽上传样式:

jQuery插件实现文件上传功能(支持拖拽)

不支持拖拽的样式:

jQuery插件实现文件上传功能(支持拖拽)

代码中一些必要的地方已经写好注释了,这里也就不做过多解释,今天就先写到这里了,谢谢作者的分享。

更多精彩内容,请点击《jQuery上传操作汇总》,进行深入学习和研究。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery 1.4.2发布!主要是性能与API
Feb 25 Javascript
JavaScript String.replace函数参数实例说明
Jun 06 Javascript
JS实现的网页背景闪电闪烁效果代码
Oct 17 Javascript
精彩的Bootstrap案例分享 重点在注释!(选项卡、栅格布局)
Jul 01 Javascript
jquery实现网站列表切换效果的2种方法
Aug 12 Javascript
AngularJS入门教程之更多模板详解
Aug 19 Javascript
jQuery+CSS3实现四种应用广泛的导航条制作实例详解
Sep 17 Javascript
JS作用域闭包、预解释和this关键字综合实例解析
Dec 16 Javascript
基于jquery.page.js实现分页效果
Jan 01 jQuery
vue中子组件的methods中获取到props中的值方法
Aug 27 Javascript
微信小程序学习笔记之函数定义、页面渲染图文详解
Mar 28 Javascript
Vue父子传递实例讲解
Feb 14 Javascript
jQuery插件实现图片轮播特效
Jun 16 #Javascript
javascript正则表达式之分组概念与用法实例
Jun 16 #Javascript
js学习阶段总结(必看篇)
Jun 16 #Javascript
原生js封装二级城市下拉列表的实现代码
Jun 16 #Javascript
jQuery获取剪贴板内容的方法
Jun 16 #Javascript
javascript作用域、作用域链(菜鸟必看)
Jun 16 #Javascript
全面理解JavaScript中的继承(必看)
Jun 16 #Javascript
You might like
上海地方志办公室-上海电子仪表工业志
2021/03/04 无线电
使用sockets:从新闻组中获取文章(三)
2006/10/09 PHP
下拉列表多级联动dropDownList示例代码
2013/06/27 PHP
php中的curl_multi系列函数使用例子
2014/07/29 PHP
定义select的边框颜色
2008/04/28 Javascript
FLASH 广告之外的链接
2008/12/16 Javascript
setTimeout的延时为0时多个浏览器的区别
2012/05/23 Javascript
jquery图片不完全按比例自动缩小的简单代码
2013/07/29 Javascript
JavaScript中使用typeof运算符需要注意的几个坑
2014/11/08 Javascript
JavaScript中的值类型转换介绍
2014/12/31 Javascript
javascript实现 百度翻译 可折叠的分享按钮列表
2015/03/12 Javascript
详细介绍jQuery.outerWidth() 函数具体用法
2015/07/20 Javascript
概述一个页面从输入URL到页面加载完的过程
2016/12/16 Javascript
JS请求servlet功能示例
2017/06/01 Javascript
微信小程序自定义模态对话框实例详解
2017/08/16 Javascript
初探JavaScript 面向对象(推荐)
2017/09/03 Javascript
基于JavaScript实现前端数据多条件筛选功能
2020/08/19 Javascript
Webpack框架核心概念(知识点整理)
2017/12/22 Javascript
解决使用bootstrap的dropdown部件时报错:error:Bootstrap dropdown require Popper.js问题
2018/08/30 Javascript
详解JavaScript添加给定的标签选项
2018/09/17 Javascript
Vue数字输入框组件使用方法详解
2020/02/10 Javascript
vue实现商品列表的添加删除实例讲解
2020/05/14 Javascript
[02:10]2018DOTA2亚洲邀请赛赛前采访-Liquid
2018/04/03 DOTA
深入源码解析Python中的对象与类型
2015/12/11 Python
使用Django Form解决表单数据无法动态刷新的两种方法
2017/07/14 Python
使用pycharm生成代码模板的实例
2018/05/23 Python
python模块之subprocess模块级方法的使用
2019/03/26 Python
PyCharm搭建Spark开发环境实现第一个pyspark程序
2019/06/13 Python
python 绘制拟合曲线并加指定点标识的实现
2019/07/10 Python
django xadmin action兼容自定义model权限教程
2020/03/30 Python
学习焦裕禄同志为人民服务思想汇报
2014/09/10 职场文书
夫妻双方自愿离婚协议书
2014/10/24 职场文书
2014幼儿园家长工作总结
2014/11/10 职场文书
2014年实习期工作总结
2014/11/27 职场文书
初中生毕业评语
2014/12/29 职场文书
励志正能量20句:送给所有为梦想拼搏的人
2019/11/11 职场文书