Plone 搜索功能在plone.app.search包中实现;请求中包含的sort_on变量用于控制搜索模板上结果的排序顺序。
默认情况下,当此变量没有值时,Plone 使用相关性作为排序顺序。
迄今为止最简单的方法是什么(最新的)?
Plone 搜索功能在plone.app.search包中实现;请求中包含的sort_on变量用于控制搜索模板上结果的排序顺序。
默认情况下,当此变量没有值时,Plone 使用相关性作为排序顺序。
迄今为止最简单的方法是什么(最新的)?
您需要自定义搜索视图以设置新的排序选项,并在未设置排序时更改默认排序。
如果您仍然需要能够按相关性排序,请使用一个非空值,然后在filter_query
方法中更改该值:
from plone.app.search.browser import _, Search, SortOption
class MyCustomSearch(Search):
def filter_query(self, query):
query = super(MyCustomSearch, self).filter_query(query)
if 'sort_on' not in query:
# explicitly set a sort; if no `sort_on` is present, the catalog sorts by relevance
query['sort_on'] = 'EffectiveDate'
query['sort_order'] = 'reverse'
elif query['sort_on'] == 'relevance':
del query['sort_on']
return query
def sort_options(self):
""" Sorting options for search results view. """
return (
SortOption(self.request, _(u'date (newest first'),
'EffectiveDate', reverse=True
),
SortOption(self.request, _(u'relevance'), 'relevance'),
SortOption(self.request, _(u'alphabetically'), 'sortable_title'),
)
然后将此视图注册到您的站点;如果您使用最简单的主题层:
<configure
xmlns="http://namespaces.zope.org/zope"
xmlns:browser="http://namespaces.zope.org/browser"
i18n_domain="plone">
<browser:page
name="search"
layer=".interfaces.IYourCustomThemeLayer"
class=".yourmodule.MyCustomSearch"
permission="zope2.View"
for="*"
template="search.pt"
/>
<browser:page
name="updated_search"
layer=".interfaces.IYourCustomThemeLayer"
class=".yourmodule.MyCustomSearch"
permission="zope2.View"
for="Products.CMFCore.interfaces.IFolderish"
template="updated_search.pt"
/>
</configure>
您需要从包中复制search.pt
和updated_search.pt
模板。plone.app.search