JavaScriptベースのフロントエンドアプリケーションとして AnuglarJS を使用して
サーバ側のデータを操作する為にバックエンドAPIを Rails で構築しているのですが、
ng-file-uploadを採用した画像のアップロードが上手く出来なくて困っています。
Shop(1) <-> Item(n)
1件のShopに複数のItemが紐付いている状態で、Shopのedit画面で画像のアップロードを実装しています。
itemリストのループの中でそれぞれのitemに画像を登録させたいですが、ループの中では適切にアップロードができません。
(厳密にはcontrollerの $scope.upload = (files) -> が呼び出されません。。)
また、現状ではそれぞれのitemごとに画像を設定することができなくて詰まっています。。
APIを通してDBには正しく格納できているのでページをリロードすればきちんと表示されるのですが、
img ngf-src="files[0]" ngf-default-src="" ngf-accept="'image/*'"
がすべてのinputに対して共通のために、関係のないitemのimgが上書きされていしまいます。
一度に複数の画像アップロードや画像以外のアップロードは求めていなく、
いたってシンプルなものをつくろうとしているのですがなかなか上手くいきません...
どうかご教授いただけますと嬉しいです。
application.js
//= require angular.min //= require angular-resource.min //= require ng-file-upload.min //= require ng-file-upload-shim.min //= require app //= require_tree .
controller.coffee
angular.module('app').controller "ArticleEditController", ($scope, Upload, Shop, Item) -> $scope.init = -> $scope.$watch 'files', -> $scope.upload $scope.files return $scope.upload = (files) -> if files and files.length alert "success" i = 0 while i < files.length file = files[i] $scope.upload = Upload.upload( url: '/api/shops/1/items' method: 'POST' # shop_idを動的に渡せていないので一時的にベタ書きしています fields: 'item[shop_id]':'1' file: file fileFormDataName: 'item[image]') i++ return
edit.html.slim
# ループの外では適切にアップロードされる section p select file: input type="submit" value="ファイルを選択" ngf-select="" ng-model="files" img ngf-src="files[0]" ngf-default-src="" ngf-accept="'image/*'" section p select file: input type="submit" value="ファイルを選択" ngf-select="" ng-model="files" img ngf-src="files[0]" ngf-default-src="" ngf-accept="'image/*'" section p select file: input type="submit" value="ファイルを選択" ngf-select="" ng-model="files" img ngf-src="files[0]" ngf-default-src="" ngf-accept="'image/*'" # ループの中では $scope.upload = (files) -> が呼ばれない... ul ng-repeat="item in shop.items" p select file: input type="submit" value="ファイルを選択" ngf-select="" ng-model="files" img ngf-src="files[0]" ngf-default-src="" ngf-accept="'image/*'"

回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2015/07/22 04:32
2015/07/22 05:02
退会済みユーザー
2015/07/22 08:44
退会済みユーザー
2015/07/23 04:26 編集
2015/07/23 06:06
退会済みユーザー
2015/07/24 04:25
2015/07/24 05:03
退会済みユーザー
2015/07/24 07:28