pcrt / yii2-ajax-pager
Yii2-select2 小部件实现
1.0.31
2021-07-20 10:28 UTC
README
Yii2 组件扩展 yii\widgets\ContentDecorator url,用于向 GridView 和 ListView 基础组件添加 AJAX 分页功能。
此扩展创建了一个围绕内容的包装器,允许选择“分页模式”或“无限滚动模式”来管理分页功能,而无需重新加载页面。
##安装
安装此扩展的最佳方式是通过 composer。
运行以下命令之一
$ php composer.phar require pcrt/yii2-ajax-pager "@dev"
或
"pcrt/yii2-ajax-pager": "@dev"
将以下内容添加到您的 composer.json
文件的 require 部分。
使用方法
扩展安装完成后,您可以在视图中添加组件:组件可以作为分页使用
use pcrt/Paginator; .... <?php Paginator::begin([ 'type' => 'Pagination', 'id' => 'pcrt-pagination', // Id of pagination container 'id_wrapper' => 'pcrt-pagination-wrapper', // Id of wrapper container 'view' => $this, ]) ?> $this->renderPartial('ajax/list', [ 'dt' => $dataProvider ]); // or do your magic here ! <?php Paginator::end() ?>
或无限滚动模式
use pcrt/Paginator; .... <?php Paginator::begin([ 'type' => 'InfiniteScroll', 'append' => '.pcrt-card', // Selector for pagination element extractor 'id_wrapper' => 'pcrt-pagination-wrapper', // Id of wrapper container 'view' => $this, ]) ?> $this->renderPartial('ajax/_card', [ 'dt' => $dataProvider ]); // or do your magic here ! <?php Paginator::end() ?>
您还可以传递一个可选的“包装视图”文件
use pcrt/Paginator; .... <?php Paginator::begin([ 'type' => 'InfiniteScroll', 'viewFile' => '@app/views/wrapper.php', // Alternative view Wrapper 'append' => '.pcrt-card', // Selector for pagination element extractor 'id_wrapper' => 'pcrt-pagination-wrapper', // Id of wrapper container 'view' => $this, ]) ?> // Remenber to return $content variable inside of wrapper;
对于无限滚动,在控制器中返回一个 renderAjax 文件
class MyController extends Controller { public function actionGetGridView(){ public function actionGetGridView($pageNumber=0,$pageSize=50){ if($pageSize == ""){ $pageSize = 50; } $request = \Yii::$app->request; $searchModel = new MyControllerSearch(); $dataProvider = $searchModel->search(Yii::$app->request->queryParams); $dataProvider->pagination = [ 'pageSize'=>$pageSize, 'page'=>$pageNumber-1, ]; $result = $dataProvider->getTotalCount(); $data = $this->renderAjax('_list', [ 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, ]); return $data; } } }
对于分页,返回一个包含数据(HTML 渲染)和总数(元素总数)的 JSON 对象
class MyController extends Controller { public function actionGetGridView($pageNumber=0,$pageSize=50){ \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON; if($pageSize == ""){ $pageSize = 50; } $request = \Yii::$app->request; $searchModel = new MyControllerSearch(); $dataProvider = $searchModel->search(); $dataProvider->pagination = [ 'pageSize'=>$pageSize, 'page'=>$pageNumber-1, ]; $result = $dataProvider->getTotalCount(); $data = $this->renderAjax('_list', [ 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, ]); return ['html'=>$data,'total'=>$result]; } }
许可
Yii2-Ajax-Pager 在 BSD-3 许可证下发布。有关详细信息,请参阅附带的 LICENSE.md
文件。
有用的 URL
享受!