创建文章分页



嗨,我正在使用silverstripe 2.4.7,我很难让分页工作。我在page.php中创建了一个函数来获取最新的文章,如下所示

function AllNewsPosts($num=1) { 
$news = DataObject::get_one("NewsHolder"); 
return ($news) ? DataObject::get("NewsEntry", "ParentID > 0", "Date DESC", "", $num) : false; 
}

然后,当我把这个功能到控制和分页标签一篇文章显示,但链接到并发文章不工作-基本上分页不工作,我不知道如何修复它

<% if AllNewsPosts %>
        <% control AllNewsPosts %>
          <div class="event">
           <h2>$MenuTitle |<span class="date"> $Date.Time $Date.Long</span></h2>
           <p>$Content.FirstParagraph</p>
            <a href="$Link">See more about this event</a>
          </div>
        <% end_control %> 
        <% else %>
        <div class="no-entry">'There are no entries'</div>
        <% end_if %>
        <% if AllNewsPosts.MoreThanOnePage %>
  <div id="PageNumbers">
    <p>
      <% if AllNewsPosts.NotFirstPage %>
        <a class="prev" href="$AllNewsPosts.PrevLink" title="View the previous page"><span class="yellow-background">Prev</span></a>
      <% end_if %>
      <span>
          <% control AllNewsPosts.PaginationSummary(0) %>
          <% if CurrentBool %>
            <span class="current">$PageNum</span>
          <% else %>
            <% if Link %>
              <a href="$Link" class="numbers" title="View page number $PageNum">$PageNum</a>
            <% else %>
              &hellip;
            <% end_if %>
          <% end_if %>
        <% end_control %>
      </span>
      <% if AllNewsPosts.NotLastPage %>
        <a class="next" href="$AllNewsPosts.NextLink" title="View the next page"><span class="yellow-background">Next</span></a>
      <% end_if %>
    </p>
  </div>
<% end_if %>

任何帮助都非常感谢

注意:以下答案适用于Silverstripe 2.4。这不应该用于Silverstripe 3.0+站点。从3.0开始,PaginatedList对象使分页更加容易。

您没有设置查询中检索条目的数量限制,或者从哪里开始。

下面的教程解释了如何将分页应用于一组数据对象,正如你正在尝试做的那样:http://www.ssbits.com/tutorials/2010/paginating-a-filtered-dataobjectset/

这是一个尝试修改你的函数,包括限制和开始需要分页:

PHP

function AllNewsPosts() {
    if(!isset($_GET['start']) || !is_numeric($_GET['start']) || (int)$_GET['start'] < 1) 
    {
        $_GET['start'] = 0;
    }
    $SQL_start = (int)$_GET['start'];
    $newsEntries = DataObject::get('NewsEntry', '', 'Date DESC');
    $doSet = new DataObjectSet();
    foreach ($newsEntries as $newsEntry) {
        if ($newsEntry->canView()) {
            $doSet->push($newsEntry);
        }
    }
    $doSet->setPageLimits($SQL_start, 10, $doSet->Count());
    return $doSet;
}

注意上面将每页显示10个条目。

最新更新