我有这段代码:
$("#uploadMe").change(function(e) {
var input = $(this);
var file = input[0].files[0];
var fileName = file.name;
var template = '<div class="j_upload_item">' +
'<span class="j_label">Uploading <pre></pre></span>' +
'<div class="j_upload_progress progress progress-striped active">' +
'<div class="bar" style="width: 0%"></div>' +
'</div>' +
'</div>';
box = $("#j_upload_box").append(template);
box.hide();
box.fadeIn(200);
box.find('pre').text(fileName);
bar = box.find('.bar');
formData = new FormData($('form')[1]);
$.ajax({
url: '/admin/callbacks/upload.php?type=email-attachment', //server script to process data
type: 'POST',
xhr: function() { // custom xhr
var myXhr = $.ajaxSettings.xhr();
if(myXhr.upload){ // check if upload property exists
myXhr.upload.addEventListener('progress',progressHandler, false); // for handling the progress of the upload
}
return myXhr;
},
//Ajax events
beforeSend: beforeSendHandler,
success: successHandler,
error: errorHandler,
// Form data
data: formData,
//Options to tell JQuery not to process data or worry about content-type
cache: false,
contentType: false,
processData: false
});
function beforeSendHandler(e) {
bar.css('width', '0%');
}
function successHandler(data) {
data = $.parseJSON(data);
bar.parent('div').addClass('progress-success');
bar.css('width', '100%').delay(3000).queue(function(next) {
box.fadeOut(500);
next();
});
var curval = $("#j_attachments").val();
var arr = $.makeArray(curval);
arr.push(data.name);
$("#j_attachments").val(arr);
}
function errorHandler(e) {
console.log(e);
}
function progressHandler(e) {
bar.css('width', ((e.loaded / e.total) + '%'));
}
});
$("uploadMe")
是文件输入。该脚本应该上传文件并显示由template
定义的小进度框。而不是像他们应该的那样逐渐消失和消失的盒子,每次change
事件被触发时它们都会不断弹出。
所以会发生的事情是我最终将3个盒子堆叠在一起,里面装着相同的东西。
如果您需要澄清,请询问。这真让我烦恼:(
答案 0 :(得分:2)
试试这个: -
bar.css('width', '100%').delay(3000).queue(function(next) {
box.fadeOut(500,function(){
$(this).empty(); //empty the container.
});
next();
});
问题是你每次都在添加j_upload_item
并且没有清空容器,而fadeIn在容器上,所以它只会弹出附加的消息,这些消息会在每次上传文件时累积起来。
答案 1 :(得分:0)
我看到你正在做
box = $("#j_upload_box").append(template);
每次触发更改事件时,都会附加一个新的div ...也许这是你的问题?