作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我读了这两篇很棒的文章:
The state of angularjs controllers乔纳森·克里默
和
Rethinking AngularJS Controllers托德·莫托
在这些文章中,作者讨论了使用 Controller (使它们成为 View 和模型之间的桥梁)和工厂/服务(业务逻辑应该真正存在的地方)的正确方法。
这是很好的信息,我很高兴开始在我的一个项目中重构 Controller ,但我很快发现,如果你有一个丰富的对象模型,文章中显示的结构就会崩溃。
以下是“重新思考 Angularjs Controller ”中设置的回顾:
这是 Controller :
app.controller('InboxCtrl', function InboxCtrl (InboxFactory) {
var vm = this;
vm.messages = InboxFactory.messages;
vm.openMessage = function (message) {
InboxFactory.openMessage(message);
};
vm.deleteMessage = function (message) {
InboxFactory.deleteMessage(message);
};
InboxFactory
.getMessages()
.then(function () {
vm.messages = InboxFactory.messages;
});
});
app.factory('InboxFactory', function InboxFactory ($location, NotificationFactory) {
factory.messages = [];
factory.openMessage = function (message) {
$location.search('id', message.id).path('/message');
};
factory.deleteMessage = function (message) {
$http.post('/message/delete', message)
.success(function (data) {
factory.messages.splice(index, 1);
NotificationFactory.showSuccess();
})
.error(function () {
NotificationFactory.showError();
});
};
factory.getMessages = function () {
return $http.get('/messages')
.success(function (data) {
factory.messages = data;
})
.error(function () {
NotificationFactory.showError();
});
};
return factory;
});
providers
(工厂)是单例的,数据跨 View 维护,无需从 API 重新加载即可访问。
messages
是顶级对象 .但如果他们不是,会发生什么?如果这是一个用于浏览其他用户收件箱的应用程序怎么办?也许您是管理员,并且您希望能够管理和浏览任何用户的收件箱。也许您需要同时加载多个用户的收件箱。这是如何运作的?问题是收件箱消息存储在服务中,即
InboxFactory.messages
.
Organization
|
__________________|____________________
| | |
Accounting Human Resources IT
| | |
________|_______ _____|______ ______|________
| | | | | | | | |
John Mike Sue Tom Joe Brad May Judy Jill
| | | | | | | | |
Inbox Inbox Inbox Inbox Inbox Inbox Inbox Inbox Inbox
messages
在层次结构中很深的几个层次,它们本身没有任何意义。工厂不能存储消息,
InboxFactory.messages
因为您必须一次检索多个用户的消息。
user
的上下文中,谁在
department
的上下文中,这是在
organization
的上下文中.数据应该如何以及在哪里存储?应该如何取回?
最佳答案
您可以使用丰富的对象模型,但对于不是顶级的对象,它们的工厂应该公开一个用于创建新实例的 api,而不是用作单例。这与你现在看到的许多应用程序的设计有些相反,这些应用程序比面向对象更实用——我没有评论这两种方法的优缺点,我不认为 Angular 会强制你采用非此即彼。
您的示例,重新设计,伪代码:
app.controller('InboxCtrl', function InboxCtrl (InboxFactory) {
var inbox = InboxFactory.createInbox();
$scope.getMessages = function(){
inbox.getMessages()
.then(...)
$scope.deleteMessages = function(){
inbox.deleteMessages()
.then(...)
});
关于AngularJS : How should controllers and factories/services be structured with a rich, 分层对象模型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29683316/
我是一名优秀的程序员,十分优秀!