很多时候,我们会对多个数据进行分页处理,例如我最近开发的一个功能,系统消息,系统消息的来源是多个表,而且多个表之间的数据没有任何关联,这个时候,需要对多个表进行查询,查询返回的数据进行分页,而且采用的是异步无刷新分页。

使用的是YII的ArrayDataProvider:具体位置:

怎样引入?

打开看它的命名空间:

namespace yii\data;

到项目的引用方式:

use yii\data\ArrayDataProvider;

具体使用:

public function actionMessagesystem(){
$list = [
array('id'=>1,'username'=>'aa','password'=>'aaaaaaaaaaaa','create_time'=>1),
array('id'=>2,'username'=>'bb','password'=>'bbbbbbbbbbbb','create_time'=>3),
array('id'=>3,'username'=>'cc','password'=>'cccccccccccc','create_time'=>5),
array('id'=>4,'username'=>'dd','password'=>'dddddddddddd','create_time'=>7),
array('id'=>5,'username'=>'ee','password'=>'eeeeeeeeeeee','create_time'=>8),
array('id'=>6,'username'=>'ff','password'=>'ffffffffffff','create_time'=>9),
array('id'=>7,'username'=>'gg','password'=>'gggggggggggg','create_time'=>12),
array('id'=>8,'username'=>'hh','password'=>'hhhhhhhhhhhh','create_time'=>10),
array('id'=>9,'username'=>'jj','password'=>'jjjjjjjjjjjj','create_time'=>10),
array('id'=>10,'username'=>'qq','password'=>'qqqqqqqqqqqq','create_time'=>10),
array('id'=>11,'username'=>'www','password'=>'wwwwwwwwwww','create_time'=>20),
array('id'=>12,'username'=>'xx','password'=>'xxxxxxxxxxxx','create_time'=>10),
array('id'=>13,'username'=>'zz','password'=>'zzzzzzzzzzzz','create_time'=>10),
];
// $page = 2;
$provider = new ArrayDataProvider([
'allModels' => $list,
'sort' => [
'attributes' => ['id', 'username', 'password','create_time'],
'defaultOrder' => [
'create_time'=>SORT_DESC,
'id'=>SORT_ASC
]
],
'pagination' => [
'page' => 0,
'pageSize' => 3
],
]);
echo $provider->getCount(); // 获取分页的数量
echo $provider->getTotalCount(); //获取分页总数
$lists = $provider->getModels(); // 获取分页后的数据
p($lists);
echo "message system";
}

注意这里 page=>0 表示的是异步请求第一页,如果不是异步可以这样做:

示例

http://xx.xxx.com/test/index(默认地址) 默认返回 前十条数据

http://xx.xxx.com/test/index?page=2 第二页数据

http://xx.xxx.com/test/index?sort=-key 数组key值倒序,倒序排序后十条

http://xx.xxx.com/test/index?sort=-key&page=3&page_size=20 分页大小为20,倒序排序第三页

参考:

https://blog.csdn.net/baijingdong/article/details/53302485

yii---对数组进行分页的更多相关文章

  1. PHP基于数组的分页函数(核心函数array_slice())

    关于数组的分页函数,用数组进行分页的好处是可以方便的进行联合多表查询,只需要将查询的结果放在数组中就可以了以下是数组分页的函数,函数page_array用于数组的分页,函数show_array用于分页 ...

  2. php数组内容分页的例子(转)

    php数组内容分页代码 时间:2016-03-04 23:46:34来源:网络 导读:php数组内容分页代码,当前页如果大于总页数,当前页为最后一页,分页显示时,应该从多少条信息开始读取数据.   p ...

  3. php基于数组的分页实现

    关于数组的分页函数,用数组进行分页的好处是可以方便的进行联合多表查询,只需要将查询的结果放在数组中就可以了以下是数组分页的函数,函数page_array用于数组的分页,函数show_array用于分页 ...

  4. Yii 自带的分页实例

    yii自带的分页很好用,简单的几行代码就能把分页搞出来,唯一恼火的是只能写在controller中,所以有时候controller中的方法有点臃肿.废话少说,上代码上图. 一.代码实例: 1.控制器中 ...

  5. PHP二维数组的分页

    方法一: <?php $arr_click = array( array( 'clicks' => 3, 'clickDate' =>'2015-10-11' ), array( ' ...

  6. mysql 数据库封装类:返回索引、关联、字符串数组;分页查询封装类 :$page=new Page(表的总条数,每页的条数);$sql = "".$page->limit; echo $page->fpage();

    <?php class czy { public $host="localhost"; //地址 public $uid="root"; //用户名 pu ...

  7. Yii 框架ajax搜索分页

    要想实现ajax搜索分页 其实很简单 第一步:在 Yii 框架自带的搜索和分页正常运行的情况下,在视图层

  8. 小笔记(三):PHP使用thinkphp3.2.3对数组进行分页

    之前写过thinkphp3.2.3直接在查询数据的时候进行分页,前段时间用到了将查询之后的数组进行整理后进行分页,用到的一个函数array_slice($arr, $start, $length,tr ...

  9. Yii的数组助手类

    获取值 用原生PHP从一个对象.数组.或者包含这两者的一个复杂数据结构中获取数据是非常繁琐的. 你首先得使用isset 检查 key 是否存在, 然后如果存在你就获取它,如果不存在, 则提供一个默认返 ...

随机推荐

  1. 使用java启动mybatis generator

    1.java工程目录结构: |src/main/java |com.leslie.mybatis.generator |MybatisGeneratorUtil.java |src/main/reso ...

  2. Qt OpenGL裁剪测试

    剪裁测试(Scissor Test)用于限制绘制区域. 我们可以指定一个矩形的剪裁窗口,当启用剪裁测试后,只有在这个窗口之内的像素才能被绘制,其它像素则会被丢弃. 换句话说,无论怎么绘制,剪裁窗口以外 ...

  3. 解决PHP中文乱码问题

    1.指定链接字符串编码: $mysql_server_name="localhost"; //数据库服务器名称 $mysql_username="root"; ...

  4. java okhttp发送post请求

    java的httpclient和okhttp请求网络,构造一个基本的post get请求,都比py的requests步骤多很多,也比py的自带包urllib麻烦些. 先封装成get post工具类,工 ...

  5. Linux+Redis实战教程_day02_3、redis数据类型_4、String命令_5、hash命令_6、java操作redis数据库技术

    3. redis数据类型[重点] redis 使用的是键值对保存数据.(map) key:全部都是字符串 value:有五种数据类型 Key名:自定义,key名不要过长,否则影响使用效率 Key名不要 ...

  6. SVN的Hooks功能--强制添加注释

    所谓hooks,可以类似 理解Linux内核Netfilter框架的hook点和hook函数的概念.当用户在维护代码的过程中,其执行的相关动作正好触发了相关hook点,就 会去执行对应hook点的脚本 ...

  7. vue时间格式化

    export function formatTime(date, fmt) { if (/(y+)/.test(fmt)) { fmt = fmt.replace(RegExp.$1, (date.g ...

  8. 【Cesium】坐标理解(转)

    https://blog.csdn.net/qq_34149805/article/details/78393540 1. 经纬度转换为世界坐标 第一种方式:直接转换: Cesium.Cartesia ...

  9. ASP正则匹配方法

    方法二:找到匹配的进行替换 ip="127.0.0.1" Function ReplaceTest(str,patrn, replStr) Dim regEx, str1 Set ...

  10. 关于OSG+QT+VS版本的问题

    CMake3.10.0 Qt5.11.0安装包只有VS2017_64版本,没有VS2017的32位版本,有VS2015的32位版本 Qt5.11.0+osg3.4在CMake的时候,会出现 CMake ...