Как удалить или заменить строки (not set)
в моем GridView и ListView?
Yii2: Удалить "(не установлен)" в GridView и DetailView для нулевых значений
Ответ 1
Два способа, которыми я знаю (сейчас):
Formatter
Установите nullDisplay of Formatter для чего-то другого, кроме нулевого. Вы можете сделать это в глобальной конфигурации или для одного 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) : '',
],
...
],
]) ?>
Два подсказки
Если одновременно используется несколько подходов: установка значения (напрямую или по функциям) переопределяет конфигурацию форматирования Grid/DetailView, а это, в свою очередь, переопределяет глобальную конфигурацию форматирования.
Вы также можете определить что-то отличное от пустой строки. Например. если используется бутстрап, вы можете использовать '<span class="glyphicon glyphicon-question-sign"></span>'
для получения символа для отсутствующих значений.
Ответ 2
установить emptycell в конфигурацию gridveiw:
<?= 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 : '-';
}
Ответ 3
для 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;
Ответ 4
Я бы не рекомендовал установить метод nullDisplay. Лучше всего проверить, имеет ли переменная, к которой вы обращаетесь, значение null или нет.
Я бы сделал
//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;
},
],
...
],
]); ?>