Отображение значения с использованием AJAX для загрузки

Привет, это мой файл JS для загрузки

var uploader = new plupload.Uploader({
runtimes : 'html5,flash,silverlight,html4',
browse_button : 'pickfiles', // you can pass in id...
container: document.getElementById('container'), // ... or DOM Element itself
url : '../../assets/php/upload.php',
flash_swf_url : '../js/Moxie.swf',
silverlight_xap_url : '../js/Moxie.xap',

filters : {
    max_file_size : '10mb',
    mime_types: [
        {title : "Image files", extensions : "jpg,gif,png"},
        {title : "Video files", extensions : "mp4"}
    ]
},

init: {
    PostInit: function() {
        document.getElementById('filelist').innerHTML = '';

        document.getElementById('uploadfiles').onclick = function() {
            uploader.start();
            return false;
        };
    },

    FilesAdded: function(up, files) {
        plupload.each(files, function(file) {
            document.getElementById('filelist').innerHTML += '<div id="' + file.id + '">' + file.name + ' (' + plupload.formatSize(file.size) + ') <b></b></div>';
        });
    },

    UploadProgress: function(up, file) {
        document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = '<span>' + file.percent + "%</span>";
    },

    Error: function(up, err) {
        document.getElementById('console').innerHTML += "\nError #" + err.code + ": " + err.message;
    }
}
});

uploader.init();

В моем upload.php я возвращаю

echo $name

Я хочу, чтобы в моем plupload отображалось имя $ после завершения загрузки.

Я пробовал это решение Как мне вернуть данные через Ajax с помощью Plupload при завершении загрузки?

uploader.bind('FileUploaded', function(upldr, file, object) {
var myData;
try {
    myData = eval(object.response);
} catch(err) {
    myData = eval('(' + object.response + ')');
}
alert(myData.result);

Но когда я добавляю его в свой код, он продолжает возвращать «Ваш браузер не поддерживает HTML5, Flash, silverlight, html4».

Если я возьму метод Fileuploaded, он будет работать нормально.


person Stephenmelb    schedule 19.02.2014    source источник


Ответы (1)


Разобрался. Должно получиться вот так.

UploadProgress: function(up, file) {
        document.getElementById(file.id).getElementsByTagName('b')[0].innerHTML = '<span>' + file.percent + "%</span>";
    },
            FileUploaded: function(up, file, info) {
            // Called when a file has finished uploading
            document.getElementById('console').innerHTML += "#" + info.response + ": ";
           var myData;
               try {
    myData = eval(info.response);
} catch(err) {
    myData = eval('(' + info.response + ')');
}
$("#video_id").val(info.result);
            },
    Error: function(up, err) {
        document.getElementById('console').innerHTML += "\nError #" + err.code + ": " + err.message;
    }
person Stephenmelb    schedule 19.02.2014