2017-09-26 207 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

相關問題