1

我稍微修改了演示以在我的 Rails 应用程序中使用。这些插件在 Chrome 和 FF 中运行良好,但在 IE 中存在问题。

在 IE(所有版本)中,我一一选择多个文件并开始上传。该插件只上传一个文件。如果我选择单个文件上传,那么什么也不会发生。

这是main.js的内容

$(function () {
    'use strict';

    // Initialize the jQuery File Upload widget:
    $('#fileupload').fileupload();

    // Enable iframe cross-domain access via redirect option:
    $('#fileupload').fileupload(
        'option',
        'redirect',
        window.location.href.replace(
            /\/[^\/]*$/,
            '/cors/result.html?%s'
        )
    );

    //Reference :
    // https://github.com/blueimp/jQuery-File-Upload/issues/1324
    // https://github.com/blueimp/jQuery-File-Upload/issues/841
    $('#fileupload').bind('fileuploadsubmit', function (e, data) {
        var inputs = data.context.find(':input');
        if (inputs.filter('[required][value=""]').first().focus().length) {
            return false;
        }
        data.formData = inputs.serializeArray();
    });

    $('#fileupload').bind('fileuploadadd', function (e, data) {
        alert('file added');
    });


    $('#fileupload').fileupload('option', {
        url: '/gallery',
        maxFileSize: 5000000,
        acceptFileTypes: /(\.|\/)(gif|jpe?g|png)$/i,
        process: [
            {
                action: 'load',
                fileTypes: /^image\/(gif|jpeg|png)$/,
                maxFileSize: 20000000 // 20MB
            },
            {
                action: 'resize',
                maxWidth: 1440,
                maxHeight: 900
            },
            {
                action: 'save'
            }
        ]
    }).bind('fileuploadstop', function (e, data) {
        alert('files uploaded');
      });

});

从演示 html 中,我删除了除了 + 添加文件和开始上传按钮和进度条相关代码之外的所有内容。

有人可以帮我纠正这个问题吗?

4

1 回答 1

0

最后我在@Jignesh的帮助下找到了根本原因。

在我们的应用程序中,我们通过提供两种选择要上传的文件的方式来自定义行为:1) + 添加文件按钮 2) 链接

观察到的行为:通过手动单击+ 添加文件按钮上传的所有文件都有效并成功上传。

但是,使用链接选择的文件不会。原因是链接以编程方式触发+ 添加文件按钮上的CLICK事件,IE 不支持该按钮,因此不会为使用链接选择上传的文件发起 POST 请求。

控制台还显示错误:在 IE 的情况下,上述观察到的行为被拒绝 SCRIPT5 访问。

参考:

  1. https://stackoverflow.com/a/1829817
  2. https://github.com/blueimp/jQuery-File-Upload/issues/1382
  3. https://github.com/blueimp/jQuery-File-Upload/issues/457
于 2012-09-14T13:15:39.957 回答