2017-09-26 109 views
0

我有一个现有的Angular Factory,并且在插入一些需要将$ resource的结果传递给我的Angular Controller的新代码时遇到了一些麻烦。我试图在下面显示的“sendFilesToController()”函数中执行此操作。我不确定语法。任何帮助表示赞赏。将数据从工厂传递到角度控制器

感谢,

皮特


我厂是这样的:

(function() { 
    'use strict'; 

    angular 
     .module('ooApp.controllers') 
     .factory('fileManager', fileManager); 


    fileManager.$inject = ['$q', 'fileManagerClient', 'appInfo', 'sharedPropertiesSvc', 'FileSvc', '$location', 'growl', ]; 

    function fileManager($q, fileManagerClient, appInfo, sharedPropertiesSvc, FileSvc, $location, growl) { 
     var service = { 
      files: [], 
      load: load, 
      upload: upload, 
      remove: remove, 
      fileExists: fileExists, 
      pass: pass, 
      status: { 
       uploading: false 
      } 
     }; 

     return service; 

     function load() { 
      appInfo.setInfo({ busy: true, message: "loading files" }) 

      service.files.length = 0; 

      return fileManagerClient.query() 
           .$promise 
           .then(function (result) { 
            result.files 
              .forEach(function (file) { 
               service.files.push(file); 
              }); 

            appInfo.setInfo({ message: "files loaded successfully" }); 

            return result.$promise; 
           }, 
           function (result) { 
            appInfo.setInfo({ message: "something went wrong: " + result.data.message }); 
            return $q.reject(result); 
           }) 
           ['finally'](
           function() { 
            appInfo.setInfo({ busy: false }); 
           }); 
     } 

     function upload(files) { 
      //ToDo Check that file extension exists here 

              item.OversightId = oversightId; 
              FileSvc.update({ Id: oversightId }, item).$promise.then(function (response) { 
               var x = 5; 


               sendFilesToController(id); 


              }); 

              return result.$promise; 
             }, 
             function (error) { 
              appInfo.setInfo({ message: "something went wrong: " + error.data.message }); 
              sharedPropertiesSvc.setDuplicateFileSwitch(true); 
              sharedPropertiesSvc.setDupFileMsg(error.data.error.message); 

              var url = '/oa/?id=' + oversightId; 
              $location.url(url); 

              return $q.reject(error); 
             }) 
             ['finally'](
             function() { 
              appInfo.setInfo({ busy: false }); 
              service.status.uploading = false; 
             }); 
     } 

     function sendFilesToController(id) { 
      //appInfo.setInfo({ busy: true, message: "deleting file " + file.ImageName }); 


      return { 

       sendFiles: function() { 

        //return FileSvc.getById({ Id: oversightId }).$promise.then(function (response) { 
        //}); 
        var files = {}; 
        FileSvc.getById({ Id: id }).success(function (response) { 
         angular.copy(response, files); 
        }); 
        return files; 
       } 

     } 


     } 

    } 
})(); 

,并在我的控制器我只有这个:

$scope.files = fileManagerClient.sendFiles(response); 

回答

0

你误会工厂和控制奥勒使用....

定义工厂厂=>到控制器=>

再注入要

angular.module('myExample', []) 
    .controller('myCtrl', function($scope, Factory) { 

     console.log('Factory', Factory.word); 
    }); 

// factory 
angular.module('myExample') 
    .factory('Factory', function() { 
    var factory = { }; 
    factory.word = 'example'; 
    return factory; 
}) 
+0

谢谢约瑟夫。我明白你在说什么。但是,我不确定如何在已存在的特定代码中执行此操作。 – Pete

+0

只需注入工厂并使用服务,您可以认为工厂是您的常见库文件 –

+0

我真正想要在此处执行的操作是将工厂中返回的文件绑定到控制器中的$ scope.item.Files。 – Pete

相关问题