yii2模板

GridView 小部件在开发中常用的功能及技巧。持续更新中....

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

例如,

use yii\grid\GridView;
echo yii\grid\GridView::widget([
    ‘dataProvider‘ => $dataProvider,
]);

一、表格列

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

<?php
use yii\grid\GridView;
echo GridView::widget([
    ‘dataProvider‘ => $dataProvider,

    //表格列值搜索功能,注意一定要配合attribute才会显示
    //$searchModel = new ArticleSearch();
    ‘filterModel‘ => $searchModel,

    //重新定义分页样式
    ‘layout‘=> ‘{items}<div class="text-right tooltip-demo">{pager}</div>‘,
    ‘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(‘<i class="fa fa-ban"></i> 删除‘,
                    [‘del‘, ‘id‘ => $key],
                    [
                     ‘class‘ => ‘btn btn-default btn-xs‘,
                     ‘data‘ => [‘confirm‘ => ‘你确定要删除文章吗?‘,]
                    ]
               );
             },
           ],
         ],

    ],
]);
?>

1. 处理时间

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

[
 ‘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. 处理图片

[
    ‘label‘=>‘封面图‘,
    ‘format‘=>‘raw‘,
    ‘value‘=>function($m){
        return Html::img($m->cover,
                    [‘class‘ => ‘img-circle‘,
                    ‘width‘ => 30]
        );
    }
],

3. 数据列有链接

 [
   ‘attribute‘ => ‘title‘,
   ‘value‘ => function ($model, $key, $index, $column) {
            return Html::a($model->title,
                [‘article/view‘, ‘id‘ => $key]);
    },
   ‘format‘ => ‘raw‘,
],

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

[
   ‘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‘]
]
时间: 2024-11-05 21:53:47

yii2模板的相关文章

yii2 模板twig中使用GridView::widget

yii框架twig模板中使用GridView::widget 需要这样写: {{ grid_view_widget({ 'dataProvider': provider, 'columns': [ 'id', {'attribute' : 'create_user_id', 'label' : '用户ID'}, {'attribute' : 'category_id','value':ticketCategory, 'label' : '问题分类'}, {'attribute' : 'langu

Windows下使用Composer安装yii2遇到的问题及解决方法

第一次在Windows下安装过程yii2,整个过程遇到了许多问题,历经波折,还好最后顺利解决了. 一.下载 yii2 模板 使用composer安装yii2 ,首先需要下载应用模板,其中分为基础模板和高级应用模板两种.高级模板下载 二.github token 问题: 安装yii2的应用的时候,例如使用命令 php composer.phar create-project --prefer-dist --stability=dev yiisoft/yii2-app-advanced ../yii

yii2 windows 安装过程

结合网上的资料,给出一个完整的安装过程(亲自试验过) 前提:非常重要,你的php版本必须是php5.4以上 1.首先需要下载应用模板,分为基础模板和高级应用模板,这里我以高级应用模板为例子 : 去这里现在高级应用模板 https://github.com/yiisoft/yii2-app-advanced 2.下载完之后解压放在www目录我是放在 D:\wamp\www\yii2\advanced cmd dos命令进入这个D:\wamp\www\yii2\advanced下: 3.运行 php

Yii2 高级模板不使用Apache配置目录,将前后台入口移到根目录

刚刚入手Yii2高级模板不久,部署项目时,得部署2个应用,个人感觉很繁琐,就将前后台入口文件全部拿到项目根目录.但是一看,完了,出错了!找教程找不到,还是自己解决吧 为了以后好升级,不改变Yii2核心文件,只需改2个文件就可以 将Vendor/yiisoft/yii2/web/AssetManger.php文件的69行 public $basePath = '@webroot/assets'; 改为 public $basePath = '@webroot/frontend/web/assets

Yii2.0中文开发向导——高级应用程序模板

高级应用程序模板这个模板用在大型的团队开发项目中,而且后台从前台独立分离出来以便于部署在多个服务器中.由于YIi2.0的一些新的特性,这个程序模板的功能要更深一点.提供了基本的数据库的支持,注册.密码找回等功能.安装可以通过Composer来安装如果没有安装Composer,先安装 curl -s http://getcomposer.org/installer | php 然后用如下命令来获取 php composer.phar create-project --prefer-dist --s

Yii2的相关学习记录,后台模板和gii(三)

前面已经可以正常登录,但我们需要体验下最常用的增删查改的操作.这里就需要gii,通过gii可以方便的生成表单.表格的框架,不需要我们再写重复的东西. gii访问地址:http://localhost/vishun/frontend/web/index.php?r=gii或者http://localhost/vishun/backend/web/index.php?r=gii,由于前后台文件都有配置,所以都可以访问.由于Yii框架高级版已经在common/models中存在user模型了,所以,我

[Yii2] 快速套模板,加载JS,CSS(HTML标签&lt;base&gt;)

刚开始学,弄了好久,不知道怎么加载JS.CSS,以及怎么不加载YII2自带的模板!其实真的好简单! 首先把模板放好位置, 加载JS,CSS,就在模板HTML页面加个标签:<base> base 标签的链接到JS,CSS的位置就好了,其他都不用动! <base>这个标签其实就是HTML默认打开方式与默认链接URL地址标签元素,详细了解base就在我文章里找吧! 上面弄完后,就差YII2自带的怎么去掉了,就是渲染的时候用renderPartial render和renderPartia

yii2 使用twig 模板引擎

yii2 默认使用PHP 和html 混合的方式来写视图层,但我个人还是喜欢纯模板语言的方式.而且已经非常习惯使用twig的语法,最近想使用yii2进行开发,所以还是选择使用twig视图引擎. github 已经有人提供了这样的vendor ,可以直接comoser 配置一下进行使用. composer.json 文件 require 添加 "yiisoft/yii2-twig": "*" 然后 composer update  前往common/config 下

yii2怎么继承模板

<?php /*** right is the public*/ $this->beginContent('@app/views/layouts/main.php'); /*上面就是你要继承的模板信息*/ ?> 这里就是新模板的内容 <?php $this->endContent();?> yii2怎么继承模板,这个好像可以无限继承的