在我的视图代码中,我有这个:
<?= GridView::widget([
'dataProvider' => $dataProvider,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
['label' => 'Training Score',
'attribute' => 'scoreTraining',
'format' => ['decimal',2],
],
['label' => 'Exam Score',
'attribute' => 'scoreExam',
'format' => ['decimal',2],
],
],
]);
通常,标题名称为&#34;训练分数&#34;和&#34;考试成绩&#34;
是否可以在yii2 gridview中自定义标题行?所以我的标题行看起来像2行..
<table border=1>
<tr><th>Training <br> Score</th><th>Exam <br> Score</th></tr>
</table>
&#13;
答案 0 :(得分:20)
要实现这一目标,请使用header
属性而不是label
:
<?= GridView::widget([
'dataProvider' => $dataProvider,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
[
'header' => 'Training <br> Score',
'attribute' => 'scoreTraining',
'format' => ['decimal', 2],
],
[
'header' => 'Exam <br> Score',
'attribute' => 'scoreExam',
'format' => ['decimal', 2],
],
],
]);
这样就不会对HTML内容进行编码。
官方文档:
答案 1 :(得分:11)
使用'label'属性设置标题:
http://www.yiiframework.com/doc-2.0/yii-grid-datacolumn.html# $标签细节
这样排序功能仍然有效。
使用'encodeLabel'=&gt; false允许像实体这样的HTML实体工作:
http://www.yiiframework.com/doc-2.0/yii-grid-datacolumn.html# $ encodeLabel细节
示例:
[
'attribute' => 'firstname',
'label' => 'First <br /> Name',
'encodeLabel' => false,
],