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格式错误_修改扩展名提示格式不对怎么办【技巧】

