Par*_*one 5 javascript php gridview pjax yii2
我的 Gridview 有 3 个独立的 dataProvider,一个包含已保存的数据,一个包含未保存的数据,另一个包含两者。
现在这就是我正在努力实现的目标:
如果单击“已保存”,dataProvider 将更改为已保存数据的数据提供者。
我正在尝试这样:
<?php
if($i == 1){
$dataProvider = $dataProviderSaved;
} elseif($i == 2) {
$dataProvider = $dataProviderNotsaved;
} else {
$dataProvider = $dataProviderBoth;
};
\yii\widgets\Pjax::begin(['id' => 'gridview', 'timeout' => false,
'enablePushState' => false, 'clientOptions' => ['method' => 'POST']]) ?>
<?= GridView::widget([
'dataProvider' => $dataProvider,
//regular gridview..
\yii\widgets\Pjax::end(); ?>
Run Code Online (Sandbox Code Playgroud)
JavaScript:
var i = $i;
$("#saved").click(function(){
i=1;
$.pjax.defaults.timeout = false;//IMPORTANT
$.pjax.reload({container:"#gridview"});
});
', \yii\web\View::POS_READY);
Run Code Online (Sandbox Code Playgroud)
所以,我刚刚读到在 JS 中更改 PHP 变量是“不可能的”。
如果我理解正确的话,你不需要 3 个 dataProviders。您应该使用 GridView 的FilterSelector
选项将该外部元素视为 GridView 过滤器的一部分。例如
echo GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'filterSelector' => "input[name='ModelSearch[_selection]'],",
...
Run Code Online (Sandbox Code Playgroud)
然后,在您的过滤器模型中,您根据该值进行过滤
switch($this->_selection) {
case 'Saved':
$query->andFilterWhere([...]);
break;
case 'Unsaved':
$query->andFilterWhere([...]);
break;
case 'Both':
$query->andFilterWhere([...]);
break;
Run Code Online (Sandbox Code Playgroud)
不要忘记将_selection
属性添加到模型类和搜索模型类中的规则()中作为“安全”。