Angular JS具有多个参数

时间:2016-10-19 11:30:48

标签: angularjs factory

在我的角度工厂中,我有3个函数可以返回一些代码的名称,具体取决于它们的类型:吃,感觉和来源。这是其中一项功能

   getFeelingCode: function(feelingCode) {
        var feelTag=$filter('filter')(constant.feeling_code, {code: feelingCode}, function(a, b) {
          return a === b;
        });
      if(feelTag[0])
         return feelTag[0].label;
      else
         return feelingCode;
     }

3个函数低音执行相同的操作,我想将它们转换为一个函数,如下所示:

vApp.factory('BgsFactory', function(constant, $filter) {
  return {  
      getCode: function(Code, StringCode) {
        var cst; 
        switch(StringCode) {
          case "eating_code": cst = constant.eating_code; break;
          case "feeling_code": cst = constant.feeling_code; break;
          case "source_code": cst = constant.source_code; break;
        }
        var Tag=$filter('filter')(cst, {code: Code}, function(a, b) {
          return a === b;
        });
      if(Tag[0])
         return Tag[0].label;
      else
         return Code;
    }

在我看来,我这样称呼他们

 <td>{{getSourceCode(item.tags.source)}}</td>
   <td>{{getEatingCode(item.tags.eat_code)}}</td>
   <td>{{getFeelingCode(item.tags.feeling_code)}}</td>

但我不知道如何在我的控制器中设置它们。我尝试过类似的东西,但却没有说这些功能不存在。

$scope.getEatingCode = BgsFactory.getCode("eating_code");
$scope.getFeelingCode = BgsFactory.getCode("feeling_code");
$scope.getSourceCode = BgsFactory.getCode("source_code");

我应该如何通过参数?

谢谢!

1 个答案:

答案 0 :(得分:0)

如果我没有得到错,就会像这样

$scope.getEatingCode = function(code) { return BgsFactory.getCode(code, "eating_code"); };
$scope.getFeelingCode = function(code) { return BgsFactory.getCode(code, "feeling_code"); };
$scope.getSourceCode = function(code) { return BgsFactory.getCode(code, "source_code"); };