1
我做了分页,但所有的帖子(我有8个)显示在每一页上。我想在每个页面上显示其中的4个。我的错误在哪里?我认为问题出在count($posts)
,因为在我看过的其他帖子中,他们使用的是$posts->count()
,但这种方法对我不起作用。感谢每一个建议!yii2分页不起作用
控制器动作:
public function actionIndex()
{
$searchModel = new PostSearch();
$postModel = new \app\models\Post();
$userModel = new \app\models\BlogUser();
$posts = $postModel::find()->orderBy(['post_id' => SORT_DESC])->all();
$pagination = new Pagination(['totalCount' => count($posts), 'pageSize' => 4]);
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
'postModel' => $postModel,
'userModel' => $userModel,
'posts' => $posts,
'pagination' => $pagination
]);
}
视图的index.php:
<div class="content">
<div class="row">
<?php Pjax::begin(['id' => 'posts']) ?>
<div class="col-md-12">
<?php
foreach ($posts as $post)
{
$id = $post->user_id;
$user = $userModel::find()->where(['id' => $id])->one();
echo "<div class='col-md-6 blog-post'>
<div class='col-md-3 post-prof-img'>"
. Html::img('../images/' . $user->image, ['alt' => 'image', 'class' => 'tall img-circle']) .
"<p class='text-center title-par'><strong><em> $user->username </em></strong></p>
<p class='text-center'> $post->date_create</p>
</div>
<div class='col-md-9 post-cont'><p>"
. Html::a('Click for more!',['view', 'id' => $post->post_id]) .
"</p><label class='text-center'> $post->title : </label>
<div class='fade-post'>
$post->content
</div>
</div>
</div>";
}
?>
</div>
<?php Pjax::end() ?>
</div>
</div>
<div class="row">
<div class="col-md-3">
<?= Html::a('Create Post', ['create'], ['class' => 'btn btn-primary']) ?>
<?= Html::submitButton('Search', ['class' => 'btn search-button', 'style' => 'color: blue']) ?>
</div>
</div>
好!我像你说的那样做了,但是我认为该怎么做?我很抱歉,我只是在yii2和编程方面还是新手。也将编辑我的看法! 我做的是'LinkPagination ::小部件([[我应该在这里做什么])':-) –
哪种类型的视图..你需要..一个gridview? ..一个listview ..? ..正常的分页很容易管理的小部件(gridview或列表视图小部件)..答案更新.. – scaisEdge
我只是想分裂我的布局在每个页面有4个职位,但也许我不明白分页enought: )将添加图像与我的看法,看看我想要做什么。我有6个帖子,我希望他们在这个页面上是4,其余的在第二页上。也许这对我来说是先进的:) –