在 Meteor 中添加 collection 项作为路由

Adding collection items as routes in Meteor

我有一个流星项目,我的所有用户都使用路由以这种方式设置自己的个人资料页面:

路线代码:

Router.route('/@:username', {
  name: 'profile',
  controller: 'ProfileController'
});

ProfileController = RouteController.extend({
  template: 'profile',
  waitOn: function() {
    return Meteor.subscribe('userProfile', this.params.username);
  },
  data: function() {
    var username = Router.current().params.username;
    return Meteor.users.findOne({
      username: username
    });
  }
});

服务器代码:

Meteor.publish('users', function() {
  return Meteor.users.find({}, {fields: {username: 1, emails: 1, profile: 1, roles: 1}});
});

Meteor.publish('userProfile', function(username) {
  // Try to find the user by username
  var user = Meteor.users.findOne({
    username: username
  });
  // If we can't find it, mark the subscription as ready and quit
  if (!user) {
    this.ready();
    return;
  }
  // If the user we want to display the profile is the currently logged in user
  if(this.userId === user._id) {
    // Then we return the curresonding full document via a cursor
    return Meteor.users.find(this.userId);
  } else {

    return Meteor.users.find(user._id, {
      fields: {
        profile: 0
      }
    });
  }
});

我想对我设置的页面 collection 执行类似的操作。创建 collection 有效,collection 页面有一个 _id 字段,该字段是在创建时创建的。

目前,该程序非常适合 mysite.com/@ 工作的用户。现在我希望同样的事情适用于 mysite.com/&

我基本上尝试用用户名做与我在上面的代码中做的完全相同的事情,但它没有用。我已经检查以确保我创建的 collection 项正在运行并且它们正在运行。但不知何故,我不知道如何用 collections 做同样的事情,因为我对使用路由比较陌生。

这是我尝试过的:

这是我的路线:

var pageRoute = '/&:_id';
Router.route(pageRoute, {
  name: 'page',
  controller: 'PageController'
});

PageController = RouteController.extend({
  template: 'page',
  waitOn: function() {
    return Meteor.subscribe('Page', this.params._id);
  },
  data: function() {
    var _id = Router.current().params._id;
    return Meteor.pages.findOne({
      _id: _id
    });
  }
});

服务器代码:

Meteor.publish('pages', function() {
  return Pages.find({});
});

Meteor.publish('Page', function(_id) {
  // Try find the page by _id
  var page = Meteor.pages.findOne({
    _id: _id
  });
  // If we can't find it, mark the subscription as ready and quit
  if (!page) {
    this.ready();
    return;
  }
  // If the page we want to display is not claimed, display it
  if(true) {
    return Meteor.pages.find(this._id);
  } else {
    // Redirect to the page
  }
});

页面架构Collection:

_id:, 创建于: , 由...制作: , claimedAt: , 声明者:,

更新:

我已将其缩小到这个问题,我在控制台中收到以下错误 server-side:

I20160202-11:16:24.644(2)? Exception from sub qrPage id 2kY6RKCTuCpBDbuzm TypeError: Cannot call method 'findOne' of undefined
I20160202-11:16:24.645(2)?     at [object Object].process.env.MAIL_URL [as _handler] (server/ecclesia.life_server.js:40:33)
I20160202-11:16:24.645(2)?     at maybeAuditArgumentChecks (livedata_server.js:1698:12)
I20160202-11:16:24.645(2)?     at [object Object]._.extend._runHandler (livedata_server.js:1023:17)
I20160202-11:16:24.645(2)?     at [object Object]._.extend._startSubscription (livedata_server.js:842:9)
I20160202-11:16:24.646(2)?     at [object Object]._.extend.protocol_handlers.sub (livedata_server.js:614:12)  
I20160202-11:16:24.646(2)?     at livedata_server.js:548:43                                                   

每当我尝试指向 mysite.com/&<_id>

时,就会出现此错误

基于此网站:https://perishablepress.com/stop-using-unsafe-characters-in-urls/

看起来 # 被认为是在 URL 字符串中使用的不安全字符。在上面的网页上,您似乎可以使用几个符号作为安全字符。

我刚在自己的机器上试过,我认为在 URL 中引入 # 时 Meteor 的播放效果不佳。

这成功了...

出版物:

Meteor.publish('qrpages', function() {
  return QRPages.find({});
});

Meteor.publish('qrPage', function(id) {
  // Try find the qrpage by _id
  var qrpage = QRPages.find({_id: id});
  // If we can't find it, mark the subscription as ready and quit
  if (!qrpage) {
    this.ready();
    return;
  }
  return qrpage;
});

路线:

var qrpageRoute = '/$:_id';
Router.route(qrpageRoute, {
  name: 'qrpage',
  controller: 'QRController'
});

QRController = RouteController.extend({
  template: 'qrpage',
  waitOn: function() {
    var id = this.params._id;
    return Meteor.subscribe('qrPage', id);
  },
  data: function() {
    var id = this.params._id;
    return QRPages.findOne({
      _id: id
    });
  }
});