使用angular-file-upload上传多个文件

时间:2015-09-05 16:14:54

标签: angularjs angular-file-upload

我正在使用angular-file-upload将图片和表单数据上传到我的服务器。我已经能够一次成功完成一张图像。

我的问题是,在我的表单中,我需要使用单独的输入上传两个图像(以及发送其他表单数据)。我使用单独输入的原因是我的一个图像是缩略图,另一个是英雄图像。我需要能够区分它们并将每个文件路径插入到我的数据库中的各自列中。

我通过this github issue阅读了如何使用相同的输入上传多个文件,但我无法找到有关使用不同输入上传多个文件的任何内容。也许我误解了他们。

现在,如果我尝试选择标题图片,它只会更改缩略图的值。

这是我的表格:

 <form>
    ...(other text form inputs above)...
    <div class="form-group">
      <label class="col-sm-2 control-label"> Teaser</label>
      <div class="col-sm-8>
        <input class="form-control" filestyle="" accept=".png,.gif,.jpg,.jpeg" data-button-text="Choose image" type='file' data-classbutton='btn btn-default' data-classinput="form-control inline" nv-file-select='' uploader='uploader' options="{'field': 'thumbnail_url'}"
      </div>
    </div>
    <div class="form-group">
      <label class="col-sm-2 control-label"> Header Image</label>
      <div class="col-sm-8>
        <input class="form-control" filestyle="" accept=".png,.gif,.jpg,.jpeg" data-button-text="Choose image" type='file' data-classbutton='btn btn-default' data-classinput="form-control inline" nv-file-select='' uploader='uploader' options="{'field': 'header_url'}"
      </div>
    </div>

</form>

以下是我将文件发送到服务器的方法(在onCompleteAll回调中我将表单数据发送到服务器):

    $scope.uploader = new FileUploader({
      url: '/laravel/public/admin/events/thumbnail_url/file_upload',
      alias: 'files',
      headers: {
      // 'X-CSRF-Token': n/a
      },
      onBeforeUploadItem: function(item) {
        /* Laravel file name alias */
        item.alias = 'file';
      },
      onSuccessItem: function(fileItem, response, status, headers) {
        $scope.newEventForm[fileItem.field] = '/laravel/public/uploads/events/' + response.filename;
      },
      onCompleteAll: function() {
        /* Now ready to save form data */
       AdminEvent.save($scope.newEventForm).$promise.then(function(response) {
          $scope.events.push(response.data);
          toaster.pop('success', 'Added', 'Event added successfully.');
        });
      }
    });

1 个答案:

答案 0 :(得分:0)

我遇到了与ng-file-upload相同的问题,但我没有使用angular-file-upload。

因此,此解决方案可能对您有所帮助。

在我的应用中,我有用户个人资料图片和背景图片。

其中我发送的配置文件图像输入值为ng-file-upload的文件选项,但它没有提供其他选项来发送第二个文件输入值。

解决我的所作所为

  1. 创建第二个文件输入并使用与我的表属性相同的输入模型,如ng-model =“user.bg_avatar”,其中bg_avatar是我在rails中的背景图像属性。
  2. 现在您可以在角度控制器中使用用户对象(user.bg_avatar)获取第二个文件输入值,我们将发送到rails并在rails获取时将其与其他用户属性一起保存。 但是,别忘了允许这个属性。