CGridView が存在するビューの最初のレンダリングでデータをロードせず、代わりに、最初のページのロード後に後続の AJAX 要求で最初のページをロードする方法はありますか?
これは主にパフォーマンスの最適化のためです。そのCGridViewの背後にはかなり遅いデータモデルがあり、ページをすばやくロードしてから、数秒後にAJAXリクエストでデータをロードできるようにしたいと考えています。
CGridView が存在するビューの最初のレンダリングでデータをロードせず、代わりに、最初のページのロード後に後続の AJAX 要求で最初のページをロードする方法はありますか?
これは主にパフォーマンスの最適化のためです。そのCGridViewの背後にはかなり遅いデータモデルがあり、ページをすばやくロードしてから、数秒後にAJAXリクエストでデータをロードできるようにしたいと考えています。
次のようにアクションを変更できます。
public function actionIndex() {
$dataProvider = new CActiveDataProvider('User'); // The dataprovider your grid uses
if (!$this->isAjaxRequest()) {
$dataProvider->criteria->addCondition('1 = 0'); // You could also use 0, but I think this is more clear
}
[...]
}
そして、javascriptセクションのビューで:
$(function() { // If you are using jQuery this is executed when the page is loaded
$.fn.yiiGridView.update("{id-of-your-grid-view}");
});
Brewer Gorge は非常に近く、彼の提案された回答のおかげで、正しい軌道に乗ることができました。これは機能します:
// Controller, after creating $dataProvider, before calling $this->render...
if (!Yii::app()->request->isAjaxRequest) {
$dataProvider->criteria->addCondition('1 = 0');
}
// View
<script type="text/javascript">
$(window).load(function() {
$('#id-of-grid').yiiGridView('update');
});
</script>
次のようにコントローラーにコードを書くだけです:
$model= new Data('search');
$model->unsetAttributes();
if(isset($_GET['Data']))
$model->attributes = $_GET['Data'];
if (!Yii::app()->request->isAjaxRequest)
$data->id=0; //or something that sure model return empty