php gridview,PHP编程:yii2-GridView在开发中常用的功能及技巧总结

《PHP编程:yii2-GridView在开发中常用的功能及技巧总结》要点:

本文介绍了PHP编程:yii2-GridView在开发中常用的功能及技巧总结,希望对您有用。如果有疑问,可以联系我们。

相关主题:YII框架

数据网格或者说 GridView 小部件是Yii中最强大的部件之一.它有一个属性名叫 dataProvider ,这个属性能够提供一个数据提供者的示例并且可以显示所提供的数据,即使用 yii\grid\GridView::columns 属性的一组列配置,在一个表格中渲染每一行数据.

例如,PHP编程

use yii\helpers\Html;

use yii\grid\GridView;

= GridView::widget([

'dataProvider' => $dataProvider,

'filterModel' => $searchModel,

'columns' => [

['class' => 'yii\grid\SerialColumn'],

'id',

]);?>

一、表格列

PHP编程

表格的列是通过 GridView 配置项中的 yii\grid\GridView::columns 属性配置的.PHP编程

use yii\grid\GridView;

echo GridView::widget([

'dataProvider' => $dataProvider,

//表格列值搜索功能,注意一定要配合attribute才会显示

//$searchModel = new ArticleSearch();

'filterModel' => $searchModel,

//重新定义分页样式

'layout'=> '{items}

{pager}
',

'pager'=>[

//'options'=>['class'=>'hidden']//关闭分页

'firstPageLabel'=>"First",

'prevPageLabel'=>'Prev',

'nextPageLabel'=>'Next',

'lastPageLabel'=>'Last',

]

'columns' => [

['class' => 'yii\grid\SerialColumn'],//序列号从1自增长

// 数据提供者中所含数据所定义的简单的列

// 使用的是模型的列的数据

'id',

'username',

// 更复杂的列数据

[

'class' => 'yii\grid\DataColumn', //由于是默认类型,可以省略

'value' => function ($data) {

return $data->name;

// 如果是数组数据则为 $data['name'] ,

例如,使用 SqlDataProvider 的情形.

},

],

['label'=>'标题','value' => 'title'],

['label'=>'文章内容','format' => 'html','value' => 'content'],

[

'label'=>'文章类别',

/*'attribute' => 'cid',产生一个a标签,点击可排序*/

'value' => 'cate.cname' //关联表

],

[

//动作列yii\grid\ActionColumn

//用于显示一些动作按钮,如每一行的更新、删除操作.

'class' => 'yii\grid\ActionColumn',

'header' => '操作',

'template' => '{delete} {update}',//只需要展示删除和更新

'headerOptions' => ['width' => '240'],

'buttons' => [

'delete' => function($url, $model, $key){

return Html::a(' 删除',

['del', 'id' => $key],

[

'class' => 'btn btn-default btn-xs',

'data' => ['confirm' => '你确定要删除文章吗?',]

]

);

},

],

],

],

]);

?>

1. 处理时间

PHP编程

数据列的主要配置项是 yii\grid\DataColumn::format 属性.它的值默认是使用 \yii\i18n\Formatter 应用组件.PHP编程

[

'label'=>'更新日期',

'format' => ['date', 'php:Y-m-d'],

'value' => 'updated_at'

],

//or

[

//'attribute' => 'created_at',

'label'=>'更新时间',

'value'=>function($model){

return date('Y-m-d H:i:s',$model->created_at);

},

'headerOptions' => ['width' => '170'],

],

2. 处理图片

PHP编程

[

'label'=>'封面图',

'format'=>'raw',

'value'=>function($m){

return Html::img($m->cover,

['class' => 'img-circle',

'width' => 30]

);

}

],

3. 数据列有链接

PHP编程

[

'attribute' => 'title',

'value' => function ($model, $key, $index, $column) {

return Html::a($model->title,

['article/view', 'id' => $key]);

},

'format' => 'raw',

],

4. 数据列显示枚举值(男/女)

PHP编程

[

'attribute' => 'sex',

'value'=>function ($model,$key,$index,$column){

return $model->sex==1?'男':'女';

},

//在搜索条件(过滤条件)中使用下拉框来搜索

'filter' => ['1'=>'男','0'=>'女'],

//or

'filter' => Html::activeDropDownList($searchModel,

'sex',['1'=>'男','0'=>'女'],

['prompt'=>'全部']

)

],

[

'label'=>'产品状态',

'attribute' => 'pro_name',

'value' => function ($model) {

$state = [

'0' => '未发货',

'1' => '已发货',

'9' => '退货,已处理',

];

return $state[$model->pro_name];

},

'headerOptions' => ['width' => '120']

]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持维易PHP.PHP编程

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值