Yii2: удалить "(не установлено) " в GridView и DetailView для значений null

Как удалить или заменить строки (not set) в моем GridView и ListView?

5 ответов


два способа, которые я знаю (теперь):

форматер

Set nullDisplay форматирования к чему-то, кроме null. Это можно сделать в глобальной конфигурации или для одного GridView или DetailView.

в глобальном масштабе (обычно в config/web.php или <application>/config/main.php файлы):

'components' => [
    ...
    'formatter' => [
        'class' => 'yii\i18n\Formatter',
        'nullDisplay' => '',
    ],
    ...
],

в некоторых GridView (то же самое с DetailView):

<?= GridView::widget([
    'dataProvider' => $myProvider,
    'formatter' => ['class' => 'yii\i18n\Formatter','nullDisplay' => ''],
    'columns'      => [
        ...
    ],
]); ?>

установите значение

наверное, не так элегантный. В определенном GridView:

<?= GridView::widget([
    'dataProvider' => $myProvider,
    'columns'      => [
        ...
        [
            'attribute' => 'some_attribute',
            'format'    => 'raw',
            'value'     => function (ModelClass $model) {
                if ($model->some_attribute != null) {
                    return $model->some_attribute; 
              //or: return Html::encode($model->some_attribute)
                } else {
                    return '';
                }
            },
        ],
        ...
    ],
]); ?>

или в определенном DetailView:

<?= DetailView::widget([
    'model'      => $model,
    'attributes' => [
        ...
        [
            'attribute' => 'some_attribute',
            'value' => $model->some_attribute != null ? $model->some_attribute : '', 
      //or: 'value' => $model->some_attribute != null ? Html::encode($model->some_attribute) : '',
        ],
        ...
    ],
]) ?>

две подсказки

если одновременно используется несколько подходов: установка значения (непосредственно или по функции) переопределяет конфигурацию форматирования сетки/DetailView, а это, в свою очередь, переопределяет глобальную конфигурацию форматирования.

вы также можете определить что-то отличное от пустой строки. Е. Г. если использовать Bootstrap-это может потребоваться использовать \yii\bootstrap\Html::icon('question-sign') (или '<span class="glyphicon glyphicon-question-sign"></span>'), чтобы получить символ для отсутствующих значений.


установить emptycell в GridView в конфиге:

<?= GridView::widget([
  'dataProvider' => $dataProvider,
  'filterModel' => $searchModel,
  'emptyCell'=>'-',
  'columns' => [
      ['class' => 'yii\grid\SerialColumn'],
.........
      ['class' => 'yii\grid\ActionColumn'],
  ],
 ]); ?>

или :

  'attribute' => 'description',
  'label' => Yii::t('app', 'description'),
  'value' => function($data) {
         return !empty($data->description) ? $data->description : '-';
   }

на kartik\grid\GridView;

'class' => 'kartik\grid\EditableColumn',
'attribute'=>'myAttribute',
'header' => 'myHeader',                                            
'editableOptions' => [                         
    'inputType' => \kartik\editable\Editable::INPUT_TEXT,
    'valueIfNull' => '-',

/**
 * @var string the value to be displayed. If not set, this will default to the attribute value. If the attribute
 * value is null, then this will display the value as set in [[valueIfNull]].
 */
public $displayValue;

используйте этот:

use Yii;

...

Yii::$app->formatter->nullDisplay = 'N\A';

Я бы не рекомендовал устанавливать метод nullDisplay. Лучше всего проверить, является ли переменная, к которой вы обращаетесь, нулевой или нет.

Я бы сделал

//model code
public function getProjectName()
{
    $project = $this->project;
    return ($project) ? $project->name : '';
}

//your gridview
<?= GridView::widget([
'dataProvider' => $myProvider,
'columns'      => [
    ...
    [
        'attribute' => 'some_attribute',
        'format'    => 'raw',
        'value'     => function (ModelClass $model) {
             $model->projectName;
        },
    ],
    ...
],
 ]); ?>