问题

我想用jQuery异步上传文件.这是我的HTML:

 <span>File</span>
<input type="file" id="file" name="file" size="10"/>
<input id="uploadbutton" type="button" value="Upload"/>
 

这里我的Jquery代码:

 $(document).ready(function () {
    $("#uploadbutton").click(function () {
        var filename = $("#file").val();

        $.ajax({
            type: "POST",
            url: "addFile.do",
            enctype: 'multipart/form-data',
            data: {
                file: filename
            },
            success: function () {
                alert("Data Uploaded: ");
            }
        });
    });
});
 

我只获得文件名.我可以做些什么来解决这个问题?

目前的解决方案

我正在使用 jQuery Form Plugin 上传文件.

  最佳答案

使用 HTML5 您可以使用Ajax和jQuery进行文件上传.不仅如此,您可以进行文件验证(名称,大小和MIME类型)或使用HTML5进度标记(或div)处理进度事件.最近我不得不进行文件上传,但我不想使用 Flash 也没有框架或插件,经过一些研究,我提出了解决方案.

HTML:

 <form enctype="multipart/form-data">
    <input name="file" type="file" />
    <input type="button" value="Upload" />
</form>
<progress></progress>
 

首先,如果您想要,您可以进行一些验证.例如,在文件的.on('change')事件中:

 $(':file').on('change', function () {
  var file = this.files[0];

  if (file.size > 1024) {
    alert('max upload size is 1k');
  }

  // Also see .name, .type
});
 

现在,$.ajax()使用按钮单击提交:

 $(':button').on('click', function () {
  $.ajax({
    // Your server script to process the upload
    url: 'upload.php',
    type: 'POST',

    // Form data
    data: new FormData($('form')[0]),

    // Tell jQuery not to process data or worry about content-type
    // You *must* include these options!
    cache: false,
    contentType: false,
    processData: false,

    // Custom XMLHttpRequest
    xhr: function () {
      var myXhr = $.ajaxSettings.xhr();
      if (myXhr.upload) {
        // For handling the progress of the upload
        myXhr.upload.addEventListener('progress', function (e) {
          if (e.lengthComputable) {
            $('progress').attr({
              value: e.loaded,
              max: e.total,
            });
          }
        }, false);
      }
      return myXhr;
    }
  });
});
 

如您所见,使用HTML5(和一些研究)文件上传不仅可能,而且非常简单.尝试使用 Google Chrome ,因为每个浏览器都不可用示例的HTML5组件.

  相同标签的其他问题

javascriptjqueryajaxasynchronousxmlhttprequest