angularjs – 如何创建一个可以在Angular中使用的自定义对象类

我是一个有角度的巨大粉丝,但它有一些棘手的概念,他们之间有非常微妙的差异,这是其中之一.

我只想创建一个我可以用来在我的角度控制器和工厂中创建自定义对象的类.它肯定不应该那么难,但我不知道如何做到这一点.我想要一个自定义的ResultSet类,我可以实例化来创建ResultSet的实例.但是对于我的生活,我无法弄清楚使用工厂v服务的正确语法.

这就是我想要的:

ResultSet = function(dataSet){ 
  this.filter = function(){ 
    # filters and returns dataSet
    # ...
  }
}

然后我想要在控制器等中实例化一个ResultSet的实例:

MyApp.controller('pageCtrl',['ResultSet',(ResultSet) ->
  # ...
  rs = ResultSet.new(dataToFilter)

如何创建一个允许我创建自定义对象的实例的服务?

使用角度服务而不是工厂似乎更正确,因为服务返回对象的实例(正是我想要的).但我不知道如何做到这一点…

我如何使用服务声明自定义ResultSet类,然后如何从其中实例化一个实例?

myApp.factory('ResulSet',function() {
    function ResultSetInstance(dataSet) { 
        this.filter = function(){ 
            // ...
        }
    }

    return {
        createNew: function(dataSet) {
            return new ResultSetInstance(dataSet);
        }
    };
});

接着

myApp.controller('pageCtrl',function(ResultSet) {
    var someData = ...;
    var rs = ResultSet.createNew(someData);
}

编辑(来自问题提问者)

在进一步尝试的时候,我发现你甚至不需要使用createNew方法.

myApp.factory('ResultSetClass',function() {
    ResultSetClass = function(dataSet) { 
        this.filter = function(){ 
            // ...
        }
    }

    return ResultSetClass
});

工作很好,然后你可以调用新的ResultSetClass(args).

注意使用Coffeescript的人

Coffeescript将返回您的类实例中的最后一个变量或方法,因此如果使用coffeescript(作为一般规则),则必须在类定义的末尾返回此变量或方法

myApp.factory 'ResultSetClass',() ->
  ResultSetClass = (dataset) ->
    this.filter = () ->
      # do some stuff
    return this

  return ResultSetClass

如果你不明确地返回,那么你会发现你打电话时

myApp.factory 'ResultSetClass',() ->
  ResultSetClass = (dataset) ->
    this.filter = () ->
      # do some stuff

那么你将只剩下coffeescript返回的最后一个过滤方法.

相关文章

ANGULAR.JS:NG-SELECTANDNG-OPTIONSPS:其实看英文文档比看中...
AngularJS中使用Chart.js制折线图与饼图实例  Chart.js 是...
IE浏览器兼容性后续前言 继续尝试解决IE浏览器兼容性问题,...
Angular实现下拉菜单多选写这篇文章时,引用文章地址如下:h...
在AngularJS应用中集成科大讯飞语音输入功能前言 根据项目...
Angular数据更新不及时问题探讨前言 在修复控制角标正确变...