jquery uploadify如何取消已上传成功文件

发布时间 - 2026-01-10 22:55:10    点击率:

如何使用uploadify进行文件上传,各位都能够在网上找到,但是需要注意版本号.我这里仅仅说一下,在文件已经成功上传到服务器之后,如何取消文件的上传.

我使用的是自动上传,即将'auto'属性设置为true.

1.首先我们要设置cancelmg属性,即设置文件上传成功后,显示在文件上的关闭图片.这里需要修改对应CSS中的代码

.uploadify-queue-item .cancel a { 
  background: url('../img/uploadify-cancel.png') 0 0 no-repeat; 
  float: right; 
  height: 16px; 
  text-indent: -9999px; 
  width: 16px; 
} 

将这里url中的uploadify-cancel.png的地址设置正确.这时可以看到上传的文件后会显示对应的取消关闭图片.当然我们不修改源码,将图片放置在img文件夹下也可以.

2.当我们使用自动上传,点击文件对应上的关闭,这时是不会触发'onCancel'事件的,(onCancel事件是针对不自动上传时进行触发的)所以我们需要需要绑定对应的事件到取消图片上.

3.当每个图片上传成功之后,都会触发”onUploadSuccess”事件.所以我们将绑定操作写在onUploadSuccess函数中.

4.代码如下:

onUploadSuccess:function(file, data, response) { 
    var cancel=$('#fileQueue .uploadify-queue-item[id="' + file.Id + '"]').find(".cancel a"); 
if (cancel) { 
  cancel.attr("deletefileid",file.id); 
  cancel.click(function () { 
    //我的处理逻辑 
    //1.首先调用ajax 传递文件名到后台,后台删除对应的文件(这个我就不写了) 
    //2.从后台返回的为true,表明删除成功;返回false,表明删除失败 
     var deletefileid = cancel.attr("deletefileid"); 
     $("#uploadify").uploadify("cancel",deletefileid);//将上传队列中的文件删除. 
  }); 
} 
} 

5.$("#uploadify").uploadify("cancel",deletefileid); 这会调用uploadify中的cancel方法,但是cancel方法中有一个问题,通过查看源码,发现cancel方法并没有将队列中的文件删除,只是在前台删除了对应的div.这样就会导致,假设当我上传文件A,已经上传成功,这时我点击删除图片,取消文件A的上传,这时前台A文件消失,但是假如我再次上传文件A,会提示我已经上传过文件A了,这显然是有问题的.
其实,uploadify的cancel方法就是针对还没有上传到服务器的文件,这时点击取消,调用cancel方法,即cancel方法针对的是还没有上传到服务器的文件.

这时我们需要修改源码将对应需要删除的文件在队列中进行删除.

cancel : function(fileID, supressEvent) { 
 
  var args = arguments; 
 
  this.each(function() { 
    // Create a reference to the jQuery DOM object 
    var $this    = $(this), 
      swfuploadify = $this.data('uploadify'), 
      settings   = swfuploadify.settings, 
      delay    = -1; 
 
    if (args[0]) { 
      // Clear the queue 
      if (args[0] == '*') { 
        var queueItemCount = swfuploadify.queueData.queueLength; 
        $('#' + settings.queueID).find('.uploadify-queue-item').each(function() { 
          delay++; 
          if (args[1] === true) { 
            swfuploadify.cancelUpload($(this).attr('id'), false); 
          } else { 
            swfuploadify.cancelUpload($(this).attr('id')); 
          } 
          $(this).find('.data').removeClass('data').html(' - Cancelled'); 
          $(this).find('.uploadify-progress-bar').remove(); 
          $(this).delay(1000 + 100 * delay).fadeOut(500, function() { 
            $(this).remove(); 
          }); 
        }); 
        swfuploadify.queueData.queueSize  = 0; 
        swfuploadify.queueData.queueLength = 0; 
        // Trigger the onClearQueue event 
        if (settings.onClearQueue) settings.onClearQueue.call($this, queueItemCount); 
      } else { 
        for (var n = 0; n < args.length; n++) { 
          swfuploadify.cancelUpload(args[n]); 
          /* 添加代码 */ 
          delete swfuploadify.queueData.files[args[n]]; 
          swfuploadify.queueData.queueLength = swfuploadify.queueData.queueLength - 1; 
          /* 添加结束 */ 
          $('#' + args[n]).find('.data').removeClass('data').html(' - Cancelled'); 
          $('#' + args[n]).find('.uploadify-progress-bar').remove(); 
          $('#' + args[n]).delay(1000 + 100 * n).fadeOut(500, function() { 
            $(this).remove(); 
          }); 
        } 
      } 
    } else { 
      var item = $('#' + settings.queueID).find('.uploadify-queue-item').get(0); 
      $item = $(item); 
      swfuploadify.cancelUpload($item.attr('id')); 
      $item.find('.data').removeClass('data').html(' - Cancelled'); 
      $item.find('.uploadify-progress-bar').remove(); 
      $item.delay(1000).fadeOut(500, function() { 
        $(this).remove(); 
      }); 
    } 
  }); 
 
}, 

总结

以上是我针对如何取消已经上传成功的文件的方法.当然如果不是自动上传,那么不用修改uploadify,直接删除就好。


# uploadify取消文件上传  # uploadify文件上传  # jquery文件上传  # JQuery上传插件Uploadify使用详解及错误处理  # JQuery.uploadify 上传文件插件的使用详解 for ASP.NET  # php+jQuery.uploadify实现文件上传教程  # Jquery Uploadify上传带进度条的简单实例  # 详解jquery uploadify 上传文件  # Jquery上传插件 uploadify v3.1使用说明  # Jquery Uploadify多文件上传带进度条且传递自己的参数  # jQuery文件上传插件Uploadify使用指南  # firefox浏览器用jquery.uploadify插件上传时报HTTP 302错误  # jquery uploadify和apache Fileupload实现异步上传文件示例  # 上传  # 的是  # 还没有  # 绑定  # 上传文件  # 文件上传  # 我就  # 就会  # 是有  # 就好  # 中有  # 当我  # 可以看到  # 如果不是  # 当我们  # 一个问题  # 后会  # 设置为  # 写在  # 这会 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么实现验证码(Captcha)功能  如何在自有机房高效搭建专业网站?  CSS3怎么给轮播图加过渡动画_transition加transform实现【技巧】  Laravel中Service Container是做什么的_Laravel服务容器与依赖注入核心概念解析  如何在橙子建站中快速调整背景颜色?  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  中山网站推广排名,中山信息港登录入口?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?  网站制作企业,网站的banner和导航栏是指什么?  如何快速搭建FTP站点实现文件共享?  如何在 Python 中将列表项按字母顺序编号(a.、b.、c. …)  iOS验证手机号的正则表达式  Laravel怎么做缓存_Laravel Cache系统提升应用速度的策略与技巧  如何在Windows服务器上快速搭建网站?  Laravel如何操作JSON类型的数据库字段?(Eloquent示例)  个人摄影网站制作流程,摄影爱好者都去什么网站?  使用豆包 AI 辅助进行简单网页 HTML 结构设计  如何快速搭建安全的FTP站点?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  用yum安装MySQLdb模块的步骤方法  b2c电商网站制作流程,b2c水平综合的电商平台?  Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】  高防服务器:AI智能防御DDoS攻击与数据安全保障  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  Laravel如何将应用部署到生产服务器_Laravel生产环境部署流程  微博html5版本怎么弄发超话_超话进入入口及发帖格式要求【教程】  Laravel集合Collection怎么用_Laravel集合常用函数详解  Laravel如何使用缓存系统提升性能_Laravel缓存驱动和应用优化方案  PHP怎么接收前端传的文件路径_处理文件路径参数接收方法【汇总】  Laravel如何实现数据库事务?(DB Facade示例)  黑客如何利用漏洞与弱口令入侵网站服务器?  如何在建站之星绑定自定义域名?  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  如何实现javascript表单验证_正则表达式有哪些实用技巧  如何在万网ECS上快速搭建专属网站?  如何做网站制作流程,*游戏网站怎么搭建?  nodejs redis 发布订阅机制封装实现方法及实例代码  Laravel如何实现全文搜索_Laravel Scout集成Algolia或Meilisearch教程  深入理解Android中的xmlns:tools属性  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  Laravel怎么使用artisan命令缓存配置和视图  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  如何选择可靠的免备案建站服务器?  Win11怎么关闭资讯和兴趣_Windows11任务栏设置隐藏小组件  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  西安专业网站制作公司有哪些,陕西省建行官方网站?  活动邀请函制作网站有哪些,活动邀请函文案?  JS弹性运动实现方法分析  php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】