知道怎么了?

时间:2013-05-27 21:44:58

标签: jquery

我有这段代码:

$("#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个盒子堆叠在一起,里面装着相同的东西。

如果您需要澄清,请询问。这真让我烦恼:(

2 个答案:

答案 0 :(得分:2)

试试这个: -

Fiddle

        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 ...也许这是你的问题?