pcrt / yii2-ajax-pager

Yii2-select2 小部件实现

安装: 910

依赖者: 2

建议者: 0

安全: 0

星标: 0

关注者: 2

分支: 0

语言:JavaScript

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

享受!