• Yii2.0 Gridview为某列增加属性


    我们知道GridView组件非常方便,会自动生成数据表格。table tr td神马的全自动生成的。但是如果想定制化稍微有点难度。

    比如想在某列td上应用样式。

    老写法是这样的

     <?= GridView::widget([
            'dataProvider' => $dataProvider,
            'layout' => "{items}
    {pager}
    {summary}",
            'summary' => '<p class="summary">当前显示第{begin} - {end}条,共{totalCount}条。</p>',
            'columns' => [
                ['class' => 'yiigridSerialColumn'],
                'name',
                [
                    // 看这里
                    'attribute' => 'propertyValuesString',
                    'format' => 'html',
                    'value' =>  function ($model, $key, $index, $column){
                        return '<div class="limit-width">'. $model->propertyValuesString .'</div>';
                    }
                ],    
                ......

    这样返回的html,td标签里面会套一层<div class="limit-width"></div>。

    如果才能将class应用在td上呢

    查了源码之后,可以这样:

             <?= GridView::widget([
          .......
             'columns' => [
                ['class' => 'yiigridSerialColumn'],
                'name',
    
                // 新增的代码
                [
                    'class' => 'yiigridColumn',
                    'contentOptions' => [
                        'class' => 'limit-width',
                    ],
              // 或者
                    'contentOptions' => ['style' => 'white-space: pre;'],
                    'header' => '类目下的所有种类',
                    'content' => function ($model, $key, $index, $column){
                        return $model->propertyValuesString;
                    }
                ],

    也就是说。该列我需要用到 yii/grid/Column类。该类有个contentOptions属性。接收匿名函数或数组。数组就是属性名和属性值得键值对。渲染时该列包含一个th和多个td。th内容从header中取,td就是content。

  • 相关阅读:
    Vuejs
    Vuejs
    Vuejs
    Vuejs
    JS高级之面试必须知道的几个点
    用vue快速开发app的脚手架工具
    作为一名前端开发工程师,你必须掌握的WEB模板引擎:Handlebars
    REST接口设计规范总结
    eclipse实现JavaWeb应用增量打包
    转载:作为面试官,我是怎么快速判断程序员能力的?
  • 原文地址:https://www.cnblogs.com/mafeifan/p/4345087.html
Copyright © 2020-2023  润新知