Yii2的Gridview应用技巧补充

Yii2框架下的Gridview通常用来展示一张DB表中的数据,十分方便。这里只说一下经常要用到的一些小技巧,其实大多数官方文档都是有的,只是有可能需要在多个文档里。

自动创建的gridview示例。

1. 不显示Gridview自带的记录序列。
删除视图文件里下面这一行代码。

复制代码
['class' => 'yii\grid\SerialColumn']

2.字段名称居中对齐
视图里自定义headerOptions。

复制代码
"headerOptions" => ['style' => 'text-align:center;'],

3.字段值居中对齐
视图里自定义contentOptions。

复制代码
"contentOptions" => ['style' => 'text-align:center;'],

4.字段不允许点击排序
视图里自定义enableSorting。

复制代码
'enableSorting' => false,

5.字段不允许搜索
Search模型里rules return值去除对应值。例如去掉分类ID以及优先级两个字段的搜索功能。

复制代码
class MaterialscatSearch extends Materialscat
{
    /**
     * @inheritdoc
     */
    public function rules()
    {
        return [
           //[['cat_id', 'status', 's'], 'integer'],
            [['status'], 'integer'],
            [['cat_name'], 'safe'],
        ];
    }

6.状态栏目显示对应值的中文含义
数据库里存放的是0和1,0代表禁用,1代表启用。
数据模型添加中文状态的静态数组和取值方法

复制代码
class Materialscat extends \yii\db\ActiveRecord
{
	public static $allStatus = [
		'0' => '禁用',
		'1' => '启用'
	];
        ...
        public function getStatusStr()
        {
		return Yii::t('app',self::$allStatus[$this->status]);
        }

然后在视图里自定义value。

复制代码
[
	'attribute' =>'status',
	'enableSorting' => false,
	'value' => 'StatusStr',   //$model->StatusStr = $model->getStatusStr();
	"headerOptions" => ['style' => 'text-align:center;width:10%;'],
	"contentOptions" => ['style' => 'text-align:center;'],
],

7.状态栏搜索变成下拉搜索样式,并且默认选中项提示为‘全部’
视图自定义filter以及filterInputOptions。

复制代码
[
	'attribute' =>'status',
	'enableSorting' => false,
	'value' => 'StatusStr',
	'filter' => Materialscat::$allStatus,
	'filterInputOptions' => ['class' => 'form-control', 'id' => null, 'prompt' => '全部'],
	"headerOptions" => ['style' => 'text-align:center;width:10%;'],
	"contentOptions" => ['style' => 'text-align:center;'],
],

最终界面如下:

posted @   牛奔  阅读(474)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
点击右上角即可分享
微信分享提示