yii2的分页和ajax分页

本文详细介绍了如何在Yii框架中使用分页类进行数据分页,并通过AJAX实现动态加载数据,包括控制器层加载分页类、查询数据、分页配置、视图层展示及AJAX调用的完整流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

要想使用Yii分页类
第一步:在控制器层加载分页类
use yii\data\Pagination;
第二步: 使用model层查询数据,并用分分页,限制每页的显示条数
$data = User::find();  //User为model层,在控制器刚开始use了field这个model,这儿可以直接写Field,开头大小写都可以,为了规范,我写的是大写
$pages = new Pagination(['totalCount' =>$data->count(), 'pageSize' => '3']);    //实例化分页类,带上参数(总条数,每页显示条数)
$model=$data->offset($pages->offset)->limit($pages->limit)
->all();

第三步:向视图层传送数据
return $this->render('show',[
            'pages' => $pages,
        ]);
传送数据的时候,用render函数,否则过去视图层没有样式

第四步:
   在视图层顶层写上
<?php
    use yii\helpers\Html;
    use yii\widgets\ActiveForm;
    use yii\widgets\LinkPager;
    use yii\helpers\Url;
?>

  在显示数据底部
<?=
LinkPager::widget([
      'pagination' => $pages,
    ]);
?>


效果:


Yii框架里面的ajax分页,其实很简单,
只需在
<?=
LinkPager::widget([
      'pagination' => $pages,
    ]);
?>
后面加上下面这段代码:
<?php $this->beginBlock('abc'); ?>
$(document).on('click','.pagination a',function(e){
    e.preventDefault();
    var url=$(this).attr('href');
    $.get(url,function(msg){
        //alert(msg);
        $('#lists').html(msg);
    });
});
<?php $this->endBlock();  $this->registerJs($this->blocks['abc'], View::POS_END); ?>
另外在视图层顶部加上这一句话
use yii\web\View;
最后的效果和上面的效果是一样的!


转载于:https://www.cnblogs.com/lmpxs/p/5344055.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值