yii---对数组进行分页
很多时候,我们会对多个数据进行分页处理,例如我最近开发的一个功能,系统消息,系统消息的来源是多个表,而且多个表之间的数据没有任何关联,这个时候,需要对多个表进行查询,查询返回的数据进行分页,而且采用的是异步无刷新分页。
使用的是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---对数组进行分页的更多相关文章
- PHP基于数组的分页函数(核心函数array_slice())
关于数组的分页函数,用数组进行分页的好处是可以方便的进行联合多表查询,只需要将查询的结果放在数组中就可以了以下是数组分页的函数,函数page_array用于数组的分页,函数show_array用于分页 ...
- php数组内容分页的例子(转)
php数组内容分页代码 时间:2016-03-04 23:46:34来源:网络 导读:php数组内容分页代码,当前页如果大于总页数,当前页为最后一页,分页显示时,应该从多少条信息开始读取数据. p ...
- php基于数组的分页实现
关于数组的分页函数,用数组进行分页的好处是可以方便的进行联合多表查询,只需要将查询的结果放在数组中就可以了以下是数组分页的函数,函数page_array用于数组的分页,函数show_array用于分页 ...
- Yii 自带的分页实例
yii自带的分页很好用,简单的几行代码就能把分页搞出来,唯一恼火的是只能写在controller中,所以有时候controller中的方法有点臃肿.废话少说,上代码上图. 一.代码实例: 1.控制器中 ...
- PHP二维数组的分页
方法一: <?php $arr_click = array( array( 'clicks' => 3, 'clickDate' =>'2015-10-11' ), array( ' ...
- mysql 数据库封装类:返回索引、关联、字符串数组;分页查询封装类 :$page=new Page(表的总条数,每页的条数);$sql = "".$page->limit; echo $page->fpage();
<?php class czy { public $host="localhost"; //地址 public $uid="root"; //用户名 pu ...
- Yii 框架ajax搜索分页
要想实现ajax搜索分页 其实很简单 第一步:在 Yii 框架自带的搜索和分页正常运行的情况下,在视图层
- 小笔记(三):PHP使用thinkphp3.2.3对数组进行分页
之前写过thinkphp3.2.3直接在查询数据的时候进行分页,前段时间用到了将查询之后的数组进行整理后进行分页,用到的一个函数array_slice($arr, $start, $length,tr ...
- Yii的数组助手类
获取值 用原生PHP从一个对象.数组.或者包含这两者的一个复杂数据结构中获取数据是非常繁琐的. 你首先得使用isset 检查 key 是否存在, 然后如果存在你就获取它,如果不存在, 则提供一个默认返 ...
随机推荐
- ADCD 1.9 ZOS 配置 CTCI-W32 TCPIP 网络
试验步骤:两步走,第一步修改Hercules的配置文件 在hercules 配置文件末尾加上 0E20-0E21 CTCI -n 0A-00-27-00-00-00 192.168.5 ...
- innodb分区
当 MySQL的总记录数超过了100万后,性能会大幅下降,可以采用分区方案 分区允许根据指定的规则,跨文件系统分配单个表的多个部分.表的不同部分在不同的位置被存储为单独的表. 1.先看下innodb的 ...
- QT编译错误:cannot find file: *.pro
编译一个之前同事写的QT程序,结果出现了编译错误:cannot find file: *.pro 解决方法:将程序放在英文路径下 尽管出现一些红色的编译信息部门,但是最终还算是编译成功了~
- npm 安装碰到SSL问题
经过仔细排查和google,原来是ssl 的问题: 解决办法: npm config set strict-ssl false
- 8 -- 深入使用Spring -- 3...1 Resource实现类UrlResource
8.3.1 Resource 实现类------UrlResource : 访问网络资源的实现类 1.访问网络资源 访问网络资源通过UrlResource 类实现,UrlResource是java.n ...
- UDP通信-UdpClient
static void Main(string[] args) { Console.WriteLine("发送端"); byte[] buffer = System.Text.En ...
- luasocket 接收数据
在游戏客户端使用luasocket作为网络通信的手段, 有一点很蛋疼, 就是它的receive是阻塞的, 那界面就卡死在那里了, 不过有一个函数:settimeout(), 传入参数0, 表示如果 ...
- lua 对表的简单序列化与反序列化
参考文档:http://blog.csdn.net/xiaodan007/article/details/7096718 function sz_T2S(_t) local szRet = " ...
- javascript使用jQuery加载CSV文件+ajax关闭异步
<script src="jquery-3.3.1.min.js"></script>定义一个csv函数// 关闭异步,否则cesium初始化的时候,csv ...
- ASP.NET MVC入门到精通——第一个ASP.NET MVC程序
开发流程 新建Controller 创建Action 根据Action创建View 在Action获取数据并生产ActionResult传递给View. View是显示数据的模板 Url请求→Cont ...