Ошибка Uploadify в IE8 - PullRequest
       20

Ошибка Uploadify в IE8

1 голос
/ 07 октября 2010

Я не могу заставить uploadify (плагин jQuery) работать в IE8, он отлично работает во всех других браузерах.

Когда я иду, чтобы загрузить файл, я получаю эту ошибку:

Объект не поддерживает это свойство или метод

И он находится на этой строке в uploadify.js:

document.getElementById(jQuery(this).attr('id') + 'Uploader').startFileUpload(ID, false);

Я не могу понять это.

JavaScript выглядит так:

<script type="text/javascript">
$(document).ready(function() {
var scriptData;

$.get('/lib/upload_params.php', {'key': "files/<?=random?>/"},
    function(data) {
        scriptData = {
            'AWSAccessKeyId': data.AWSAccessKeyId,
            'key': encodeURIComponent(data.key),
            'acl': "private",
            'policy': encodeURIComponent(data.policy),
            'signature': encodeURIComponent(encodeURIComponent(data.signature)),
            'success_action_status': "201",
            'folder':'',
            'Filename':''
        };
        //    $('#file').uploadifySettings('scriptData',scriptData);
        start_uploadify();
              },
    "json" ); 

function start_uploadify() {
    $('#file').uploadify({
        'uploader'      : 'http://domain.com/lib/uploadify/uploadify.swf',
        'script'        : 'http://cdn.domain.com',
        'multi'         : false,
        'buttonImg'     : 'http://domain.com/images/select_button.png',
        'rollover'      : true,
        'width'         : '131',
        'height'        : '40',
        'sizeLimit'     : '1073741824',
        'auto'          : false,
        'method'        : 'post',
        'scriptData'    : scriptData,  
        'scriptAccess'  : 'always',
        'wmode'         : 'transparent',
        onSelect        : function(event, queueID, fileObj) {
                            $('#send_options').show().addClass('on');
                            $('#fileUploader').css('visibility', 'hidden');
                            $('#fileQueue').css({'margin-top' : '-40px', 'visibility' : 'visible'});
                          },
        onComplete      : function(event, queueID, fileObj, response, data) {
                            //alert(fileObj.name);
                            $('#upload_progess').html("<strong>Upload complete</strong><br />We are now processing your file...");
                            $('#fn').val(fileObj.name);
                            $('#fs').val(fileObj.size);
                            $('#form_1').submit();
                           },  
        'onError'       : function(e, queueID, fileObj, errorObj){
                            //alert( dump(scriptData) );
                            if(errorObj.info == 201){
                              //$('#file'+queueID).remove();
                            } else {
                              alert(errorObj.type+' error:'+errorObj.info+'. Sorry! (try again later)');
                            }
                          },
        'folder'        : '',
        'fileDataName'  : 'file'
    });
}

$('#send').live('click', function() {
    $('#file').uploadifyUpload();
    $('#send_options').hide();
    $('#upload_progress').show();
});

$('#change_file').live('click', function() {
    $x = $('#send_options');
    $y = $('#fileUploader');
    $z = $('#fileQueue');

    if ($x.hasClass('on')) {
        $x.removeClass('on').hide();
        $y.css('visibility', 'visible');
        $z.css('visibility', 'hidden');
    } else {
        $x.addClass('on');  
    }
});

$('#method_2').delegate('', 'click', function() {
    $('.wrap_to').show();                                             
});

$('#method_1').delegate('', 'click', function() {
    $('.wrap_to').hide();                                         
});

});

Ответы [ 4 ]

1 голос
/ 18 апреля 2012

удаление этой строки:

 $('#fileUploader').css('visibility', 'hidden');

исправил проблему для меня. Я предполагаю, что IE больше не может найти элемент после того, как он был установлен как «скрытый».

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

Не уверен, поможет ли это вам, но я только что столкнулся со странной ошибкой IE8, которая может быть связана. Если у вас есть функция с именем «change_file» и есть ссылка типа <a onclick="change_file()">, то внутри формы, содержащей <input name="change_file">, вы получите сообщение об ошибке «Объект не поддерживает это свойство или метод», о чём-то бесполезно.

Хм, просто немного углубился в это, кажется, что это не просто "change_file", которое ему не нравится, это какое-то совпадение в имени функции js и именах ввода. На самом деле это имеет немного больше смысла, когда он пытается выяснить, что такое «change_file», он должен сначала посмотреть на элементы формы и найти этот элемент формы, но потом не может понять, почему вы пытаетесь рассматривать его как функция.

Так, может быть, у вас есть вход с именем "jQuery"? (Это может быть "jQuery (this) .attr ('id')". Я попробовал один с именем "document", но он находит нормальный документ просто отлично.)

0 голосов
/ 02 июля 2011

По какой-то причине IE не нравится, чтобы имя переменной совпадало с именем объекта jQuery, например:

var field1 = $ ('# field1'). Val ();

IE это не нравится, поэтому я изменил var field1 на var field1a, и он работает.

0 голосов
/ 07 октября 2010

Эта строка выглядит подозрительно:

  $('#fileUploader').css('visibility', 'hidden');

попробуйте изменить на

  $('#fileUploader').css({'visibility': 'hidden'});
...