由于一些奇怪的原因,我无法在ALL本地重现,meteor在刷新页面时不会加载任何集合,但它们可以很好地从一个状态转换到另一个状态。我已经为该集合添加了一个onready和onerror函数,但它们实际上都没有在刷新时运行。
this previous so question seems to solve the problem.我无法以他的方式解决问题,因为显然有角度的ui路由器并不尊重服务员和数据。因此,这个链接对我来说并没有多大用处。我已经尝试解决这个问题几天了,而且我一无所获。提前感谢您的帮助。
我确定我在这里发布的代码太多了,但我还是比较全面。
集合/ meetings.js
Meetings = new Mongo.Collection('meetings');
Meetings.allow({
insert: function (userId, doc) {
return userId && doc.owner === userId;
},
update: function (userId, doc, fields, modifier) {
return userId && doc.owner === userId;
},
remove: function (userId, doc) {
return userId && doc.owner === userId;
}
});
Meetings.before.insert(function(userId, doc) {
doc.created_at = new Date().getTime();
doc.owner = userId;
doc.private = true;
});
Meetings.before.update(function(userId, doc, fieldNames, modifier, options) {
modifier.$set = modifier.$set || {};
modifier.$set.updatedAt = new Date().getTime();
});
发布/ meetings.js
Meteor.publish("meetings", function () {
return Meetings.find({});
});
meetingController.js
function meetingCtrl($scope, $location, $reactive, $http) {
const vm = this;
vm.me = Meteor.userId();
vm.lastWeek = moment().add(-1, 'weeks').unix();
$reactive(vm).attach($scope);
vm.subscribe('meetings', () => [], {
onReady: function () { console.log("onReady", arguments); },
onError: function () { console.log("onError", arguments); }
});
vm.helpers({
meetings: () => Meetings.find(
{$and: [
{created_at: {$gte: this.getReactively('lastWeek')}},
{owner: this.getReactively('me')}
]})
});
index.ng.html
<div ng-repeat="meeting in vm.meetings" class="meeting">
{{meeting.name}}
</div>
router.js
.state('meetings', {
url: '/meetings',
controller: 'meetingCtrl',
controllerAs: 'vm',
templateUrl: baseUrl + 'meetings/' + template,
resolve: {
user: ($auth) => {
return $auth.requireUser();
}
}
})
答案 0 :(得分:0)
结果证明你绝对可以通过路由器解决这个问题,使用以下内容:
user: ($auth) => {
...
},
meetings: ['$q', ($q) => {
var deferred = $q.defer();
Meteor.subscribe('meetings', {
onReady: deferred.resolve,
onStop: deferred.reject
});
return deferred.promise;
}]