加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

AngularJS自定义模型对象有方法吗?

发布时间:2020-12-17 07:34:11 所属栏目:安全 来源:网络整理
导读:当你有一个 JSON $资源时,如何在获得后将结果对象转换为更具体的对象? 例如,现在它们作为一个对象数组返回,但是我希望它们作为一个“约会”对象的数组返回,这样我就可以在该约会对象上有一些方法来回答有关该约会对象的问题.例如:此预约是否有与之相关的任
当你有一个 JSON $资源时,如何在获得后将结果对象转换为更具体的对象?

例如,现在它们作为一个对象数组返回,但是我希望它们作为一个“约会”对象的数组返回,这样我就可以在该约会对象上有一些方法来回答有关该约会对象的问题.例如:此预约是否有与之相关的任何服务?是在上午还是下午预约?

起初我认为transformResponse钩子可以在ngResource中工作,但这似乎不起作用.从那里返回的不是实际的对象.似乎使用该功能,您只能在JSON解析之前修改实际数据.

最后,我怀疑这是否是一个合适的angularJS技术?或者这些辅助方法是否只显示在控制器或其他模块中并接受要处理的对象?我认为将它们包裹在物体中更清洁,但我承认我对angularJS不是很有经验.

如果您正在使用工厂并想要添加一个函数,您可以将该函数添加到返回项目的原型中( DEMO):
app.factory('Appointment',['$resource',function($resource) {
  var Item = $resource('appointments.json',{/*bindings*/},{/*actions*/});

  Item.prototype.hasServices = function() {
    if(this.services.length > 0) return true;
    else return false;
  };

  Item.prototype.partOfDay = function() {
    if(this.time.split(':')[0] > 12) return "afternoon";
    else return "morning";
  };

  return Item;

}]);

然后在控制器中的资源上访问它:

$scope.appointments = Appointment.query({},function() {
    console.log($scope.appointments[0].partOfDay())
});

或者直接在视图里面例如ng-repeat:

{{appointment.partOfDay()}}

为了回答你的上一个问题,我认为上述解决方案是一种适当的angularjs技术.只要您具有与特定资源类型相关联的功能,我认为最好将它们直接附加到相应的资源对象.当您必须将资源作为参数传递时,为什么还要在控制器中创建辅助函数?此外,函数可以在多个控制器或作用域中使用?!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读