在 waitOn 、订阅和 onBeforeAction 下订阅集合有什么区别



我想在以下订阅数据的方式中有所不同,

使用等待

waitOn:function(){
  Meteor.subscribe('//some published function)
 }

使用 onBeforeAction

Router.onBeforeAction : function(){
   Meteor.subscribe('//some published function)
 }

使用订阅

subscriptions: function() {
    this.subscribe('items');
   }

如果只想为授权用户发布数据,则可以在 onBeforeAction 中检查(如果用户已通过身份验证)路由。像这样:

Router.map(function(){
  this.route('home', {
    path : '/',
    template : 'home'
  });
  this.route('register', {
    path : '/register',
    template : 'register'
  });
  this.route('login', {
    path : '/login',
    template : 'login'
  });
  this.route('requestlisting', {
    path : '/requestlisting',
    template : 'requestlisting',
    waitOn : function(){
        return Meteor.subscribe('RequestsPublication');
    }
  });
  ...
});
var requireLogin = function () {
   if(!Meteor.user()){
       if(Meteor.loggingIn()){
          this.render(this.loadingTemplate);
       }else{
          Router.go('login');
       }
   } else {
       this.next();
   }
}
Router.onBeforeAction(requireLogin, {only: ['requestlisting',...]});

在此示例中,在 onBeforeAction 中,仅当用户登录时,才会针对"请求列表"进行路由,之后订阅任何数据都是有意义的。

最新更新