4

我曾尝试使用纯 JavaScript 在 Telescope 中实现搜索,因为看起来 FTS 需要一段时间才能实现 Meteor,而且我还无法让 2.4 与 Meteor 很好地配合使用。

我正在使用已在 Telescope 中实现的现有分页模型来显示热门/新/最佳帖子,以及当您导航到 /search/foobar 时在路由器中设置的搜索关键字的会话变量。

但是,它似乎并没有奏效。例如,当我有 100 个帖子时,常规的分页订阅只会返回其中的 25 个,而我的搜索结果只显示前 25 个中的帖子。

几天来,我一直在用头撞墙试图调试这个:有时它有效,有时它不起作用!

这是代码(我已包含所有其他搜索代码以供参考):

应用程序.js:

var resultsPostsSubscription = function() {
  var handle = paginatedSearchSubscription( 10, 'searchResults' );
  handle.fetch = function() {
    return limitDocuments( searchPosts( Session.get( 'keyword' ) ), handle.loaded() );
  };
  return handle;
};

var resultsPostsHandle = resultsPostsSubscription();

分页_sub.js:

我复制了现有的 paginatedSubscription,因为我无法将 Session var 作为 arg 传入;它需要是动态的。稍后我可能会重构。

paginatedSearchSubscription = function (perPage/*, name, arguments */) {
  var handle = new PaginatedSubscriptionHandle(perPage);
  var args = Array.prototype.slice.call(arguments, 1);

  Meteor.autosubscribe(function() {
    var subHandle = Meteor.subscribe.apply(this, args.concat([
      Session.get( 'keyword' ), handle.limit(), function() { handle.done(); }
    ]));
    handle.stop = subHandle.stop;
  });

  return handle;
}

search.js:(新文件,在 /common 目录中)

// get all posts where headline, categories, tags or body are LIKE %keyword%
searchPosts = function( keyword ) {
  var query = new RegExp( keyword, 'i' );
  var results = Posts.find( { $or: [ { 'headline': query }, { 'categories': query }, { 'tags': query }, { 'body': query } ] } );
  return results;
};

发布.js:

Meteor.publish( 'searchResults', searchPosts );

post_list.html:

<template name="posts_results">
  {{> posts_list resultsPostsHandle}}
</template>

post_list.js:

Template.posts_results.resultsPostsHandle = function() { 
  return resultsPostsHandle;
};

router.js: 导航中有一个搜索栏重定向到这里

posts_results = function( keyword ) {
  Session.set( 'keyword' , keyword );
  return 'posts_results';
};

Meteor.Router.add({
    ...
  '/search/:keyword':posts_results,
  ...
})

任何帮助将不胜感激!

4

1 回答 1

2

有点晚了,但这里有一篇关于如何在流星中实现全文搜索的完整文章。

“不编辑任何 Meteor 代码的最简单方法是使用自己的 mongodb。”

于 2014-03-27T00:06:10.750 回答