jquery uploadify如何取消已上傳成功文件
如何使用uploadify進(jìn)行文件上傳,各位都能夠在網(wǎng)上找到,但是需要注意版本號.我這里僅僅說一下,在文件已經(jīng)成功上傳到服務(wù)器之后,如何取消文件的上傳.
我使用的是自動(dòng)上傳,即將'auto'屬性設(shè)置為true.
1.首先我們要設(shè)置cancelmg屬性,即設(shè)置文件上傳成功后,顯示在文件上的關(guān)閉圖片.這里需要修改對應(yīng)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的地址設(shè)置正確.這時(shí)可以看到上傳的文件后會顯示對應(yīng)的取消關(guān)閉圖片.當(dāng)然我們不修改源碼,將圖片放置在img文件夾下也可以.
2.當(dāng)我們使用自動(dòng)上傳,點(diǎn)擊文件對應(yīng)上的關(guān)閉,這時(shí)是不會觸發(fā)'onCancel'事件的,(onCancel事件是針對不自動(dòng)上傳時(shí)進(jìn)行觸發(fā)的)所以我們需要需要綁定對應(yīng)的事件到取消圖片上.
3.當(dāng)每個(gè)圖片上傳成功之后,都會觸發(fā)”onUploadSuccess”事件.所以我們將綁定操作寫在onUploadSuccess函數(shù)中.
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.首先調(diào)用ajax 傳遞文件名到后臺,后臺刪除對應(yīng)的文件(這個(gè)我就不寫了) //2.從后臺返回的為true,表明刪除成功;返回false,表明刪除失敗 var deletefileid = cancel.attr("deletefileid"); $("#uploadify").uploadify("cancel",deletefileid);//將上傳隊(duì)列中的文件刪除. }); } }
5.$("#uploadify").uploadify("cancel",deletefileid); 這會調(diào)用uploadify中的cancel方法,但是cancel方法中有一個(gè)問題,通過查看源碼,發(fā)現(xiàn)cancel方法并沒有將隊(duì)列中的文件刪除,只是在前臺刪除了對應(yīng)的div.這樣就會導(dǎo)致,假設(shè)當(dāng)我上傳文件A,已經(jīng)上傳成功,這時(shí)我點(diǎn)擊刪除圖片,取消文件A的上傳,這時(shí)前臺A文件消失,但是假如我再次上傳文件A,會提示我已經(jīng)上傳過文件A了,這顯然是有問題的.
其實(shí),uploadify的cancel方法就是針對還沒有上傳到服務(wù)器的文件,這時(shí)點(diǎn)擊取消,調(diào)用cancel方法,即cancel方法針對的是還沒有上傳到服務(wù)器的文件.
這時(shí)我們需要修改源碼將對應(yīng)需要?jiǎng)h除的文件在隊(duì)列中進(jìn)行刪除.
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; /* 添加結(jié)束 */ $('#' + 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(); }); } }); },
總結(jié)
以上是我針對如何取消已經(jīng)上傳成功的文件的方法.當(dāng)然如果不是自動(dòng)上傳,那么不用修改uploadify,直接刪除就好。
- JQuery上傳插件Uploadify使用詳解及錯(cuò)誤處理
- JQuery.uploadify 上傳文件插件的使用詳解 for ASP.NET
- php+jQuery.uploadify實(shí)現(xiàn)文件上傳教程
- Jquery Uploadify上傳帶進(jìn)度條的簡單實(shí)例
- 詳解jquery uploadify 上傳文件
- Jquery上傳插件 uploadify v3.1使用說明
- Jquery Uploadify多文件上傳帶進(jìn)度條且傳遞自己的參數(shù)
- jQuery文件上傳插件Uploadify使用指南
- firefox瀏覽器用jquery.uploadify插件上傳時(shí)報(bào)HTTP 302錯(cuò)誤
- jquery uploadify和apache Fileupload實(shí)現(xiàn)異步上傳文件示例
相關(guān)文章
jquery無法設(shè)置checkbox選中即沒有變成選中狀態(tài)
設(shè)置以后checkbox并沒有變成選中狀態(tài),用chrome調(diào)試看了一下,checkbox中確實(shí)有checked屬性,針對這個(gè)問題,大家可以參考下本文2014-03-03使用 jQuery 實(shí)現(xiàn)表單驗(yàn)證功能
表單作為 HTML 最重要的一個(gè)組成部分,幾乎在每個(gè)網(wǎng)頁上都有體現(xiàn),例如用戶提交信息、用戶反饋信息和用戶查詢信息等,因此它是網(wǎng)站管理者與瀏覽者之間溝通的橋梁。下面通過實(shí)例代碼給大家介紹jQuery 實(shí)現(xiàn)表單驗(yàn)證功能2017-07-07jQuery使用slideUp方法實(shí)現(xiàn)控制元素緩慢收起
這篇文章主要介紹了jQuery使用slideUp方法實(shí)現(xiàn)控制元素緩慢收起的功能,實(shí)例分析了jQuery中slideUp方法的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03jquery防止重復(fù)執(zhí)行動(dòng)畫避免頁面混亂
鼠標(biāo)滑動(dòng)過快導(dǎo)致動(dòng)畫重復(fù)執(zhí)行,以至于頁面亂了,下面為大家介紹個(gè)防止重復(fù)執(zhí)行動(dòng)畫的方法2014-04-04基于jQuery實(shí)現(xiàn)的Ajax 驗(yàn)證用戶名是否存在的實(shí)現(xiàn)代碼
基于jQuery實(shí)現(xiàn)的Ajax 驗(yàn)證用戶名是否存在的實(shí)現(xiàn)代碼,需要的朋友可以參考下。2011-04-04jQuery解析XML與傳統(tǒng)JavaScript方法的差別實(shí)例分析
這篇文章主要介紹了jQuery解析XML與傳統(tǒng)JavaScript方法的差別,實(shí)例分析了jQuery與javascript解析XML文件的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03Jquery中增加參數(shù)與Json轉(zhuǎn)換代碼
有時(shí)候,我們需要進(jìn)一步轉(zhuǎn)化為json表達(dá)式,參考Ext中的Ext.urlDecode函數(shù),我們可以實(shí)現(xiàn)一個(gè)相應(yīng)的jquery中使用的函數(shù)。2009-11-11淺談jQuery中hide和fadeOut的區(qū)別 show和fadeIn的區(qū)別
下面小編就為大家?guī)硪黄獪\談jQuery中hide和fadeOut的區(qū)別 show和fadeIn的區(qū)別。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-08-08