2015-10-18 93 views
0

我有8個控制器使用12個常用功能。但3-4個功能在每個功能上都不相同。我怎麼能不在每個這些重複自己?我正在使用這些控制器的每個通用服務。我的代碼:另一個控制器在AngularJS乾燥

app.controller("ArticleController",['$scope','$http','dataService',function($scope,$http,dataService){ 

$scope.comments={}; 
$scope.articles = {articles:[]}; 
$scope.reachedEnd = false; 
$scope.getArticles //implemented differently for each of the controllers 
//Here it is used to fetch latest articles 
/* common 12 functions 
    to deal with dom events. On addition of new comments, upvotes, etc 
*/ 
function getArticlesSuccess(articles){ 
    articles.articles.forEach(function(article){ 
     $scope.articles.articles.push(article); 
    }); 
    $scope.reachedEnd = articles.reachedEnd; 
} 

$scope.addToReadingList = function(id,userid){ 
    dataService.addToReadingList(id,userid); 
}; 

$scope.removeFromReadingList = function(id,userid){ 
    dataService.removeFromReadingList(id,userid); 
}; 

$scope.upvote = function(id,userid){ 
    upvoteIncrementer(id,userid); 
    dataService.upvote(id); 
}; 

$scope.deleteComment = function(commentId){ 
    dataService.deleteComment(commentId); 
}; 

var upvoteIncrementer = function(id,userid){ 
    console.log(id); 
    $scope.articles.articles.forEach(function(article){ 
     console.log(article); 
     if(article && article._id === id && !article.votes.set){ 
      if(article.votes.down.indexOf(userid)>-1){ 
       article.votes.down.splice(article.votes.down.indexOf(userid)); 
       console.log('removed vote'); 
      } 
      article.votes.up.push(userid); 
      article.votes.set = true; 
     } 
    }); 
} 


$scope.downvote = function(id,userid){ 
    downvoteIncrementer(id,userid); 
    dataService.downvote(id); 
} 

var downvoteIncrementer = function(id,userid){ 
    console.log(id); 
    $scope.articles.articles.forEach(function(article){ 
     console.log(article); 
     if(article && article._id === id && !article.votes.set){ 
      console.log(article); 
      if(userid in article.votes.up){ 
       article.votes.up.splice(article.votes.up.indexOf(userid)); 
       console.log('removed vote'); 
      } 
      article.votes.down.push(userid); 
      article.votes.set = true; 
     } 
    }); 
} 


$scope.showComments = function(id){ 
    dataService.getComments(id).then(function(data){ 
     $scope.articles.articles.forEach(function(article){ 
      if(article._id === id){ 
       article.fetchedComments = data.comments; 
      } 
     }); 
     console.log($scope.fetchedComments); 
    }); 
} 

$scope.commentForm = function(id,user,contents) { 
    dataService.postComments(id,user,contents).then(function(x){ 
    $scope.articles.articles.forEach(function(article){ 
      if(article._id === id){ 
       article.fetchedComments.push(x); 
       console.log(article.fetchedComments); 
      } 
     }); 
    }); 
} 
}]); 

代碼:

app.controller("ArticleController",['$scope','$http','dataService',function($scope,$http,dataService){ 
$scope.comments={}; 
$scope.articles = {articles:[]}; 
$scope.reachedEnd = false; 
$scope.getArticles //implemented differently for each of the controllers 
//Here it is used to fetch top articles by the day 
/* common 12 functions */ 
}]); 

編輯:新增dataservice.js

(function(){ 

angular.module('newstalk') 
    .factory('dataService',['$http','$q',dataService]); 

function dataService($http,$q){ 
    return { 
     getArticles : getArticles, 
     postComments : postComments, 
     addToReadingList : addToReadingList, 
     getReadingList : getReadingList, 
     upvote : upvote, 
     downvote : downvote, 
     getComments : getComments, 
     removeFromReadingList : removeFromReadingList, 
     deleteComment : deleteComment 
    }; 

    function getArticles(numsRecieved){ 
     return $http({ 
      method:'get', 
      url:'/api/articles/'+parseInt(numsRecieved/10) 
     }) 
     .then(sendResponse); 
    } 

    function deleteComment(commentId){ 
     $http.delete('/api/delete/comment/'+commentId) 
      .then(function(response){console.log(response);}); 
    } 

    function sendResponse(response){ 
      return response.data; 
    } 

    function sendResponseComments(response){ 
      return response.data; 
    } 

    function postComments(id,user,contents){ 
     var uid = user._id; 
     var uname=user.name; 
     var c = contents; 
     var data = { 
      content: c, 
      id: uid, 
      name:uname 
     }; 
     console.log(data); 
     return $http.post('/api/article/'+id,data).then(sendResponse); 
    } 
    function addToReadingList(id,userid){ 
     var data = { 
      id: id, 
      user: userid 
     }; 
     $http.post('/api/user/add/'+userid,data); 
    } 

    function removeFromReadingList(id,userid){ 
     var data = { 
      id: id, 
      user: userid 
     }; 
     $http.post('/api/user/rem/'+userid,data); 
    } 

    function getReadingList(userid){ 
     console.log('/api/readinglist/0'); 
     return $http({ 
      method:'get', 
      url:'/api/readinglist/0' 
     }) 
     .then(sendResponse); 
    }   
    function upvote(id){ 
     return $http({ 
      method:'post', 
      url:'/api/article/up/'+id 
     }); 
    } 
    function downvote(id){ 
     return $http({ 
      method:'post', 
      url:'/api/article/down/'+id 
     }); 
    } 
    function getComments(id){ 
     return $http({ 
      method:'get', 
      url:'/api/article/comments/'+id 
     }) 
     .then(sendResponseComments); 
    } 

} 
})() 

請提出一個方法,這樣我可以減少代碼和必要性只在一個地區進行變革才能發揮作用。

+0

解釋更多關於你的邏輯。 dataService做了什麼?從哪裏加載數據? –

+0

deleteComment,getArticles等正在被許多控制器使用?或者每一個只用在一個控制器中? –

+0

他們正在被許多人使用。 getArticles對於每個控制器都不相同。 –

回答

2

您可以使用函數作爲服務,並讓該函數返回一個對象,使其具有需要跨控制器重用的功能。您可以在每個控制器中調用該函數,根據您使用的控制器傳遞參數來配置函數。

app.factory('myStuff', function($http) { 
    return function(urlForController) { 
    return { 
     foo: function() { 
     // use the parameters in your functions 
     return $http.get(urlForController); 
     }, 
     bar: //etc 
    }; 
    }; 
}); 

app.controller('myCtrl', function($scope, myStuff) { 
    // call the service function, passing in the controller specific parameters to configure the returned object 
    $scope.myStuff = myStuff('/whatever'); 
}); 

你甚至可以通過控制器的$scope到服務,讓這些功能操縱它你需要的。

$scope.myStuff = mystuff($scope, '/whatever'); 

// the service: 
return function(scope, urlForController) { 
+0

我正在使用它。 'dataService'僅用於此目的。不過我必須在每個控制器中調用它。由於控制器中的每個功能都處理不同的DOM元素。 –

+1

@AyushGupta他非常清楚地涵蓋了你的主要問題。如果您有幾個問題,請單獨詢問。 – Yang

+1

_將函數作爲服務使用,並使該函數返回具有您需要重用的函數的對象。太棒了! –