You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
46 lines
2.6 KiB
46 lines
2.6 KiB
10 years ago
|
Постраничное разделение данных
|
||
|
==========
|
||
|
|
||
|
В случае когда требуется отобразить слишком много данных на одной странице, эта страница зачастую
|
||
|
разделяется на несколько частей, каждая из которых содержит и отображает только часть данных за один раз.
|
||
|
Такие части называются страницами, а сам процесс называется постраничным разделением данных.
|
||
|
|
||
|
Если вы используете [источник данных](output-data-providers.md) с одним из [виджетов данных](output-data-widgets.md),
|
||
|
то в этом случае будет автоматически использовано постраничное разделение данных. В противном случае вам требуется создать объект [[\yii\data\Pagination]],
|
||
|
заполнить его такими данными как [[\yii\data\Pagination::$totalCount|общее количество элементов]],
|
||
|
[[\yii\data\Pagination::$pageSize|количество элементов на одной странице]] и [[\yii\data\Pagination::$page|текущая страница]], затем применить
|
||
|
его к запросу и передать в [[\yii\widgets\LinkPager|элемент нумерации страниц]].
|
||
|
|
||
|
|
||
|
Первым делом в действии контроллера мы создаем объект постраничного разделения данных и заполняем его данными:
|
||
|
|
||
|
```php
|
||
|
function actionIndex()
|
||
|
{
|
||
|
$query = Article::find()->where(['status' => 1]);
|
||
|
$countQuery = clone $query;
|
||
|
$pages = new Pagination(['totalCount' => $countQuery->count()]);
|
||
|
$models = $query->offset($pages->offset)
|
||
|
->limit($pages->limit)
|
||
|
->all();
|
||
|
|
||
|
return $this->render('index', [
|
||
|
'models' => $models,
|
||
|
'pages' => $pages,
|
||
|
]);
|
||
|
}
|
||
|
```
|
||
|
|
||
|
Затем в представлении мы выводим модели для текущей страницы и передаем объект постраничного разделение данных в элемент нумерации страниц:
|
||
|
|
||
|
```php
|
||
|
foreach ($models as $model) {
|
||
|
// отображаем здесь $model
|
||
|
}
|
||
|
|
||
|
// отображаем ссылки на страницы
|
||
|
echo LinkPager::widget([
|
||
|
'pagination' => $pages,
|
||
|
]);
|
||
|
```
|