我正在使用 yii bootstrap小部件TbGridView 来查看数据库表中的数据。
evry页面请求我使用偏移量从我的 API 获取数据,然后从 API <的结果更新网格视图databrovider
/强>
我使用了 CArrayDataProvider 。
我的问题是第一次请求它返回记录,它在网格视图上显示分页上的所有页面,当我点击分页上的任何页面时,它会按偏移但网格返回数据view不会在点击的页面上添加活动类。
我在分页选项中设置了 currentPage = 0 ,如果我删除此选项并点击分页上的任何页面,则返回未找到结果虽然有结果在我的数据提供者
我的代码是:
这是我的数据提供者
$offset = $limit * ($page_no-1) ;
$arr_transaction = $obj_transaction->getTransactionByOffset($offset);
$total_record = $total_record = $obj_transaction->getTotalRecord();
$dp_transactions = new CArrayDataProvider($arr_transaction,
array('id'=>'transactions',
'keyField' => false,
'pagination'=>array(
'pageSize'=>10,
'params' => array('date_from' => $transaction_form->date_from,'date_to'=>$transaction_form->date_to),
'currentPage'=>0,
),
'totalItemCount'=>$total_record,
));
这是我的网格视图
<?php
$this->widget('bootstrap.widgets.TbGridView', array(
'type'=>'striped bordered condensed',
'dataProvider'=>$dp_transactions,
'template' => "{summary}{items}{pager}",
'enablePagination'=>true,
'columns'=>array(
array('name'=>'ust_order_Id', 'header'=>'Oreder Id'),
array('name'=>'ust_create_time', 'header'=>'Transaction Time'),
array('name'=>'ust_email', 'header'=>'Email'),
array('name'=>'ust_mobile_number', 'header'=>'Mobile Number'),
array('name'=>'ust_amount', 'header'=>'Amount'),
),
));
?>
我无需向CArrayDataProvide
提供所有数据。
任何人都可以帮助我
谢谢
答案 0 :(得分:0)
这是&#34;缺陷&#34; CArrayDataProvider
的数据:数组的长度必须大于(CURRENT_PAGE-1) * PAGE_SIZE
。
因此,您可以将空值填充到数组中:
$offset = $limit * ($page_no-1) ; // it means $page_no is current page number
$arr_transaction = $obj_transaction->getTransactionByOffset($offset);
$total_record = $total_record = $obj_transaction->getTotalRecord();
$arr_transaction = array_pad($arr_transaction, -1*(count($arr_transaction) + $offset), null);
$dp_transactions = new CArrayDataProvider($arr_transaction,
array('id'=>'transactions',
'keyField' => false,
'pagination'=>array(
'pageSize'=>$limit, // $limit = 10 ?
'params' => array('date_from' => $transaction_form->date_from,'date_to'=>$transaction_form->date_to),
// 'currentPage'=>0, this not needed
),
'totalItemCount'=>$total_record,
));