Yii2 grid 算是经常用的,欢迎大家回复分享自己使用经验。
其他都没变,URL 只显示「请求地址」(因为地址太长了不方便显示),但是同时能满足URL模糊搜索的需求。
<?= GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
'token_id',
[
'label' => 'url',
'filter' => Html::activeTextInput($searchModel, 'url', ['class' => 'form-control']),
'format' => 'raw',
'value' => function ($data) {
return Html::a("请求地址", $data->url);
},
],
'shop_id',
'ip',
'created_at:datetime',
['class' => 'yii\grid\ActionColumn'],
],
]); ?>
针对状态,可以下拉搜索:
<?= GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
'user_id',
[
'label' => 'status', // 可选 复写
'attribute' => 'status',
'filter' => Html::activeDropDownList($searchModel, 'status', \common\models\Token::getStatus(), ['class' => 'form-control']),
'value' => function ($data) {
return \common\models\Token::getStatus()[$data->status];
},
],
'created_at:datetime',
'expired_at:datetime',
['class' => 'yii\grid\ActionColumn'],
],
]); ?>
Model 里面代码:
/**
* @return array
*/
public static function getStatus()
{
return [
'' => '全部',
self::STATUS_ACTIVE => '正常',
self::STATUS_DELETE => '删除',
];
}
新增一个按钮:
[
'class' => 'yii\grid\ActionColumn',
'header' => '操作',
'options' => ['width' => '100px;'],
'template' => '{view} {update} {area}',
'buttons' => [
'area' => function ($url, $model) {
return Html::a('<span class="glyphicon glyphicon-list"></span>', $url, [
'title' => Yii::t('app', 'Area'),
]);
}
],
'urlCreator' => function ($action, $model, $key, $index) {
if ($action === 'view') {
return ['view', 'id' => $model->id];
} else if ($action === 'update') {
return ['update', 'id' => $model->id];
} else if ($action === 'area') {
return ['area/index', 'group_id' => $model->id];
}
}
]
根据状态动态显示按钮
[
'class' => 'yii\grid\ActionColumn',
'header' => '操作',
'template' => '{export} {use}',
'buttons' => [
'export' => function ($url, $model) {
if($model->status==0){
return Html::a('导出 Excel', $url, [
'class' => 'btn btn-success',
]);
}
return null;
},
'use' => function ($url, $model) {
if($model->status==2){
return Html::a('投入使用', $url, [
'class' => 'btn btn-info',
'data' => [
'confirm' => "确认要投入使用吗?",
'method' => 'post',
],
]);
}
return null;
},
],
],
不好意思 可以问一个很菜的问题吗?
为什么我的search model总是会被要求有对应的table The table does not exist: {{%newssearch}}
可以给我一个你这个gridview的model 和searchmodel的文件吗 谢谢
@cindyming #6楼 没看懂你的问题,不过你可以看一下 GetYii 的源码,主要是后台代码,希望对你有帮助。
楼主,您的第一个例子代码:return Html::a("请求地址", $data->url); 最后显示的会带有HTML代码吧, 应该YII会自动给您encode,最后的结果是“尖括号a href="xxx">请求地址</a反尖括号”, 我这边是这个情况, 如何做到不encode呢?
@cindyming [#6楼](#comment6) 你应该用了关联表查询
public function getCreatedUser()
{
return $this->hasOne(User::className(), ['id'=>'created_by']);
}
则
$query = Brand::find()->alias('b');
$query = $query->joinWith("createdUser AS c_u", true, 'LEFT JOIN');