2017-04-17 13 views
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> 

posts page

答えて

2

あなたはdataProvider-> pagination->のpageSizeを使用(して、新しいページネーションとパスを作成しないでくださいレンダリングする)

$dataProvider = $searchModel->search(Yii::$app->request->queryParams); 
    $dataProvider->pagination->pageSize=4; 

とビューで、あなたは例えば使用することができます

/* index.php view file*/ 

<?= 
    ListView::widget([ 
    'dataProvider' => $dataProvider, 
    ]); 
?> 

またはGridViewの

<?= GridView::widget([ 
     'dataProvider' => $dataProvider, 
     'filterModel' => $searchModel, 
     'columns' => [ 
      ['class' => 'yii\grid\SerialColumn'], 
      'your_column1', 
      'your_column2', 
      ..... 

      ['class' => 'yii\grid\ActionColumn', 
      'contentOptions' => ['style' => 'width:84px; font-size:18px;']], 
     ], 
    ]); ?> 
+0

OKとリストビューウィジェットを!あなたが言ったように私はそれを作ったが、私はその見方で何をすべきか?申し訳ありません、私はまだyii2とプログラミングの新機能です。私のビューも編集します! 私がしたことは、 'LinkPagination :: widget([何をするか])' :-) –

+0

どのタイプのビュー..あなたが必要です..グリッドビュー?? ..リストビュー.. .. ??? ..normallyページネーションはウィジェット(グリッドビューまたはリストビューウィジェット)によって簡単に管理されています..回答更新.. – scaisEdge

+0

私はちょうどそれぞれの4つの記事で私のレイアウトを分割したいと思いますが、おそらく私はページ分割を十分に理解していませんでした: )私が何をしようとしているのかを見るために私の視野に画像を追加します。そこに私は6つの記事があり、私はそれらをこのページの4ページと残りのページを2ページ目にします。たぶんそれは私のために少し高度です:) –

関連する問題