我想知道是否还有一些其他技术可以懒散地使用?似乎很难定义一个新的比较器。 以下是CmsDateResourceComparator比较方法的代码:
public int compare(CmsResource res0, CmsResource res1) {
if (res0 == res1) {
return 0;
}
CmsDateResourceComparator key0 = m_keys.get(res0.getStructureId());
CmsDateResourceComparator key1 = m_keys.get(res1.getStructureId());
if (key0 == null) {
// initialize key if null
key0 = CmsDateResourceComparator.create(m_cms, res0, m_dateIdentifiers);
m_keys.put(res0.getStructureId(), key0);
}
if (key1 == null) {
// initialize key if null
key1 = CmsDateResourceComparator.create(m_cms, res1, m_dateIdentifiers);
m_keys.put(res1.getStructureId(), key1);
}
if (m_asc) {
// sort in ascending order
if (key0.m_date > key1.m_date) {
return 1;
}
if (key0.m_date < key1.m_date) {
return -1;
}
} else {
// sort in descending order
if (key0.m_date > key1.m_date) {
return -1;
}
if (key0.m_date < key1.m_date) {
return 1;
}
}
答案 0 :(得分:1)
从OpenCms 8开始,您可以使用Solr byQuery 收集器。使用此收集器,您可以执行solr查询。这是一个强大的功能......
<cms:contentload collector="byQuery" 2 param="type:v8flower">
<cms:contentaccess var="content" />
${content.value.Title}
</cms:contentload>