jQuery-File-Upload - TypeError:$(...).fileupload不是一个函数

Dan*_*llo 4 jquery jquery-file-upload

我在我的简单页面JSP中有我的html/js代码:

<script type="text/javascript" src="jquery-2.1.1.min.js"></script>
<script type="text/javascript" src="jquery.ui.widget.js"></script>
<script type="text/javascript" src="jquery.iframe-transport.js"></script>
<script type="text/javascript" src="jquery.fileupload.js"></script>
<body>

<form id="MyID" method="post" action="JSFPAGE" enctype="multipart/form-data">

<span class="btn btn-success fileinput-button">
   <i class="glyphicon glyphicon-plus"></i>
      <span>Select files...</span>
      <input id="fileupload" type="file" name="files[]" multiple>
</span><br><br>
<!-- The global progress bar -->
<div id="progress" class="progress">
    <div class="progress-bar progress-bar-success">
    </div>
</div>
<!-- The container for the uploaded files -->
<div id="files" class="files">
</div>

<script type="text/javascript">
$(function () {
    'use strict';
    // Change this to the location of your server-side upload handler:
    var url = 'xUpload.xsp';
    $('#fileupload').fileupload({
        url: url,
        dataType: 'json',
        done: function (e, data) {
            $.each(data.result.files, function (index, file) {
                $('<p/>').text(file.name).appendTo('#files');
            });
        },
        progressall: function (e, data) {
            var progress = parseInt(data.loaded / data.total * 100, 10);
            $('#progress .progress-bar').css(
                'width',
                progress + '%'
            );
        }
    }).prop('disabled', !$.support.fileInput)
        .parent().addClass($.support.fileInput ? undefined : 'disabled');
});
</script>
</form>
</body>
Run Code Online (Sandbox Code Playgroud)

这很简单......所有JS资源都可以.但是在控制台中我看到了这个错误:

TypeError:$(...).fileupload不是函数$('#fileupload').fileupload({

你对我的问题有任何建议吗?

rom*_*rom 6

我有同样的问题,我只是在关闭body标签之前移动了js文件并且它有效:

<script type="text/javascript" src="jquery-2.1.1.min.js"></script>

<body>

<form id="MyID" method="post" action="JSFPAGE" enctype="multipart/form-data">

<span class="btn btn-success fileinput-button">
   <i class="glyphicon glyphicon-plus"></i>
      <span>Select files...</span>
      <input id="fileupload" type="file" name="files[]" multiple>
</span><br><br>

...

<script type="text/javascript">
$(function () {
    'use strict';
    // Change this to the location of your server-side upload handler:
    var url = 'xUpload.xsp';
    $('#fileupload').fileupload({
        url: url,
        dataType: 'json',
        done: function (e, data) {
            $.each(data.result.files, function (index, file) {
                $('<p/>').text(file.name).appendTo('#files');
            });
        },
       ...
});
</script>

</form>
<script type="text/javascript" src="jquery.ui.widget.js"></script>
<script type="text/javascript" src="jquery.iframe-transport.js"></script>
<script type="text/javascript" src="jquery.fileupload.js"></script>
</body>
Run Code Online (Sandbox Code Playgroud)


cal*_*ian 4

我通过访问 BlueImp 在线演示网站自行解决了这个问题。该项目的 GitHub 存储库可以在https://github.com/blueimp/jQuery-File-Upload找到。如果您查看他们的源代码,很明显您需要两个文件来帮助在您的项目中完成这项工作。1. jquery.ui.widget.js和 2. jquery.fileupload.js

如果您将这些文件包含在您的应用程序中,则文件上传的代码将起作用。您将需要 UI 小部件文档作为文件上传文件的依赖项。

如果您正在寻找这方面的可行示例,Heroku 有一篇不错的文章,无论您是否使用 Heroku,它都将帮助指导您。Rails 中直接上传 S3 图像

快乐编码!