今天就跟大家聊聊有關如何在YII2框架中使用分頁組件,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
首先我們創建操作數據表的AR模型:
<?php
namespace app\models;
use yii\db\ActiveRecord;
class MyUser extends ActiveRecord
{
public static function tableName()
{
return '{{%user}}';
}
}然后創建分頁的控制器:
<?php
namespace app\controllers;
use YII;
use app\models\MyUser;
use yii\data\Pagination;
use yii\web\Controller;
class IndexController extends Controller
{
public function actionIndex()
{
$name = YII::$app->request->get('name', '');
$where = '1=1 ';
$param = [];
//如果查詢條件很多,可以按這種方式,拼where條件
if (!empty($name)) {
$where .= "AND name=:name";
$param = array_merge($param, [':name' => $name]);
}
//設置分頁大小,為了演示,我寫成了2
$pageSize = 2;
$user = MyUser::find()->where($where, $param);
//創建分頁組件
$page = new Pagination([
//總的記錄條數
'totalCount' => $user->count(),
//分頁大小
'pageSize' => $pageSize,
//設置地址欄當前頁數參數名
'pageParam' => 'p',
//設置地址欄分頁大小參數名
'pageSizeParam' => 'pageSize',
]);
//獲取數據
$data = $user->orderBy('id DESC')
->offset($page->offset)
->limit($page->limit)
->asArray()
->all();
return $this->renderPartial('index', [
'data' => $data,
'page' => $page,
]);
}
}最后就是顯示數據分頁:
<!doctype html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<title>分頁顯示</title>
<style>
.page li {
display: inline-block;
border: 1px solid #ccc;
border-radius: 3px;
padding: 2px 3px;
}
.page li.active a {
font-weight: bold;
}
.page li a {
text-decoration: none;
}
.page li a, .page li span {
color: #666;
}
</style>
</head>
<body>
<ul>
<?php foreach ($data as $item): ?>
<li><?php echo $item['id']; ?> <?php echo $item['name']; ?></li>
<?php endforeach; ?>
</ul>
<?php
echo \yii\widgets\LinkPager::widget([
'pagination' => $page,
'firstPageLabel' => '首頁',
'lastPageLabel' => '尾頁',
'nextPageLabel' => '下一頁',
'prevPageLabel' => '上一頁',
//設置class樣式
'options' => ['class' => 'page'],
]) ?>
</body>
</html>最后效果如下:

看完上述內容,你們對如何在YII2框架中使用分頁組件有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。