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

前端技术 2023/09/08 JavaScript

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

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

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

下面附上一个例子:

<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> 

效果图:

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

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

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

4、6个事件处理程序:

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


在使用这个对象上传文件的时候,我们需要注意一点,需要在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\';

支持拖拽上传样式:

不支持拖拽的样式:

代码中一些必要的地方已经写好注释了,这里也就不做过多解释,今天就先写到这里了,谢谢作者的分享。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持phpstudy。

本文地址:https://www.stayed.cn/item/21880

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。