流星集合不会在刷新

时间:2016-02-09 18:20:24

标签: javascript angularjs meteor angular-meteor

由于一些奇怪的原因,我无法在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();
    }
  }
})

1 个答案:

答案 0 :(得分:0)

结果证明你绝对可以通过路由器解决这个问题,使用以下内容:

    user: ($auth) => {
        ...
    },
    meetings: ['$q', ($q) => {
      var deferred = $q.defer();

      Meteor.subscribe('meetings', {
        onReady: deferred.resolve,
        onStop: deferred.reject
      });

      return deferred.promise;
    }]