jQuery: загрузка изображения в fileinput.change (); - PullRequest
1 голос
/ 14 декабря 2010

У меня есть элемент управления вводом файла в моей html-форме, который автоматически загружает изображение на сервер после того, как оно было получено пользователем:

<input id="uploadedfile" name="uploadedfile" type="file" class="file" />

Я прикрепил это событие к $ (document) .ready

//uploader event
$('#uploadedfile').change(function(){
    ajaxFileUpload();
});

//upload file
function ajaxFileUpload(){
    $.ajaxFileUpload({
        url:'upload.php',
        secureuri:false,
        fileElementId:'uploadedfile',
        dataType: 'json',
        success: function(data,status){
            if(typeof(data.error) != 'undefined'){
                if(data.error){
                    //print error
                    alert(data.error);
                }else{
                    //clear
                    $('#img img').attr('src',url+'cache/'+data.msg);
                }
            }
        },
        error: function(data,status,e){
            //print error
            alert(e);
        }
    });
    return false;
}

Проблема big в том, что она работает только при первом выборе файла.Любые дальнейшие выборки входного файла не будут выполнять функцию ajaxFileUpload () - хотя, если я заменю ajaxFileUpload () на alert () в .change () Если это действительно работает.

Дополнительные методы для загрузки (ошибка, безусловно, не здесь)

jQuery.extend({
    createUploadIframe: function(id,uri){
        var frameId = 'jUploadFrame' + id;
        if(window.ActiveXObject){
            var io = document.createElement('<iframe id="' + frameId + '" name="' + frameId + '" />');
            if(typeof uri== 'boolean') {
                io.src = 'javascript:false';
            } else if(typeof uri== 'string') {
                io.src = uri;
            }
        } else {
            var io = document.createElement('iframe');
            io.id = frameId;
            io.name = frameId;
        }
        io.style.position = 'absolute';
        io.style.top = '-1000px';
        io.style.left = '-1000px';
        document.body.appendChild(io);
        return io
    },
    createUploadForm: function(id,fileElementId){
        var formId = 'jUploadForm' + id;
        var fileId = 'jUploadFile' + id;
        var form = $('<form action="" method="POST" name="' + formId + '" id="' + formId + '" enctype="multipart/form-data"></form>');
        var oldElement = $('#' + fileElementId);
        var newElement = $(oldElement).clone();
        $(oldElement).attr('id',fileId);
        $(oldElement).before(newElement);
        $(oldElement).appendTo(form);
        $(form).css('position','absolute');
        $(form).css('top','-1200px');
        $(form).css('left','-1200px');
        $(form).appendTo('body');
        return form;
    },
    ajaxFileUpload: function(s){
        s = jQuery.extend({},jQuery.ajaxSettings,s);
        var id = new Date().getTime();
        var form = jQuery.createUploadForm(id,s.fileElementId);
        var io = jQuery.createUploadIframe(id,s.secureuri);
        var frameId = 'jUploadFrame' + id;
        var formId = 'jUploadForm' + id;
        if(s.global && ! jQuery.active++) {
            jQuery.event.trigger('ajaxStart');
        }
        var requestDone = false;
        var xml = {}
        if(s.global)
            jQuery.event.trigger('ajaxSend',[xml,s]);
        var uploadCallback = function(isTimeout){
            var io = document.getElementById(frameId);
            try {
                if(io.contentWindow) {
                    xml.responseText = io.contentWindow.document.body?io.contentWindow.document.body.innerHTML:null;
                    xml.responseXML = io.contentWindow.document.XMLDocument?io.contentWindow.document.XMLDocument:io.contentWindow.document;
                } else if(io.contentDocument) {
                    xml.responseText = io.contentDocument.document.body?io.contentDocument.document.body.innerHTML:null;
                    xml.responseXML = io.contentDocument.document.XMLDocument?io.contentDocument.document.XMLDocument:io.contentDocument.document;
                }
            } catch(e) {
                jQuery.handleError(s,xml,null,e);
            }
            if(xml || isTimeout == 'timeout') {
                requestDone = true;
                var status;
                try {
                    status = isTimeout != 'timeout' ? 'success' : 'error';
                    if(status != 'error') {
                        var data = jQuery.uploadHttpData(xml,s.dataType);
                        if(s.success)
                            s.success(data,status);
                        if(s.global)
                            jQuery.event.trigger('ajaxSuccess',[xml,s]);
                    } else
                        jQuery.handleError(s,xml,status);
                } catch(e) {
                    status = 'error';
                    jQuery.handleError(s,xml,status,e);
                }
                if(s.global)
                    jQuery.event.trigger('ajaxComplete',[xml,s]);
                if(s.global && ! --jQuery.active)
                    jQuery.event.trigger('ajaxStop');
                if(s.complete)
                    s.complete(xml,status);
                jQuery(io).unbind();
                setTimeout(function(){
                    try {
                        $(io).remove();
                        $(form).remove();   
                    } catch(e) {
                        jQuery.handleError(s,xml,null,e);
                    }                                   
                },100);
                xml = null;
            }
        }
        if(s.timeout > 0) {
            setTimeout(function(){
                if(!requestDone) uploadCallback('timeout');
            },s.timeout);
        } try {
            var form = $('#' + formId);
            $(form).attr('action',s.url);
            $(form).attr('method','POST');
            $(form).attr('target',frameId);
            if(form.encoding) {
                form.encoding = 'multipart/form-data';
            } else {
                form.enctype = 'multipart/form-data';
            }
            $(form).submit();
        } catch(e) {
            jQuery.handleError(s,xml,null,e);
        }
        if(window.attachEvent){
            document.getElementById(frameId).attachEvent('onload',uploadCallback);
        } else {
            document.getElementById(frameId).addEventListener('load',uploadCallback,false);
        }
        return {abort: function () {}};
    },
    uploadHttpData: function(r,type) {
        var data = !type;
        data = type == 'xml' || data ? r.responseXML : r.responseText;
        if(type == 'script')
            jQuery.globalEval(data);
        if(type == 'json')
            eval('data = ' + data);
        if(type == 'html')
            jQuery("<div>").html(data).evalScripts();
        return data;
    }
})

Любые идеи будут оценены.Спасибо!

Ответы [ 2 ]

1 голос
/ 06 мая 2011

Просто поместите присоединение как последнюю запись в обработчик succes и error вызова $ .ajaxFileUpload в вашей функции ajaxFileUpload, и он будет работать при последующих щелчках.

Так выглядит это

//uploader event
$('#uploadedfile').change(function(){
  ajaxFileUpload();
});

//upload file
function ajaxFileUpload(){
  $.ajaxFileUpload({
    url:'upload.php',
    secureuri:false,
    fileElementId:'uploadedfile',
    dataType: 'json',
    success: function(data,status){
        if(typeof(data.error) != 'undefined'){
            if(data.error){
                //print error
                alert(data.error);
            }else{
                //clear
                $('#img img').attr('src',url+'cache/'+data.msg);
            }
        }
        $('#uploadedfile').change(function(){
          ajaxFileUpload();
        });
    },
    error: function(data,status,e){
        //print error
        alert(e);
        $('#uploadedfile').change(function(){
          ajaxFileUpload();
        });
    }
  });
  return false;
}

Но опять же, jQuery.handleError больше не существует с 1.5

0 голосов
/ 14 декабря 2010

почему вы пытаетесь заново изобрести колесо?

Используйте плагин jquery form

В примерах есть раздел о загрузке ajax ..

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...