流星集合不会在刷新时加载

meteor collections don't load on refresh

本文关键字:刷新 加载 集合 流星      更新时间:2023-09-26

出于某种奇怪的原因,我根本无法在本地复制,meteor 在刷新页面时不会加载任何集合,但它们在从状态过渡到状态时工作得很好。 我已经在集合中添加了一个 onready 和 onerror 函数,但它们实际上都没有在刷新时运行。

前面的这个问题似乎解决了问题。 我无法像他那样解决问题,因为显然 Angular 的 UI 路由器不尊重 Waiton 和数据。 因此,该链接对我来说没有多大用处。 几天来我一直在尝试解决这个问题,但一无所获。 提前感谢您的帮助。

确定我在这里发布了太多代码,但我宁愿全面。

集合/会议.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();
});

出版物/会议.js

Meteor.publish("meetings", function () {
  return Meetings.find({});
});

会议控制器.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')}
        ]})
    });

索引.ng.html

  <div ng-repeat="meeting in vm.meetings" class="meeting">
    {{meeting.name}}
  </div>

路由器.js

.state('meetings', {
  url: '/meetings',
  controller: 'meetingCtrl',
  controllerAs: 'vm',
  templateUrl: baseUrl + 'meetings/' + template,
  resolve: {
    user: ($auth) => {
      return $auth.requireUser();
    }
  }
})

事实证明,您绝对可以通过路由器解决此问题,使用以下方法:

    user: ($auth) => {
        ...
    },
    meetings: ['$q', ($q) => {
      var deferred = $q.defer();
      Meteor.subscribe('meetings', {
        onReady: deferred.resolve,
        onStop: deferred.reject
      });
      return deferred.promise;
    }]