我的教师模型中有一个函数,它返回类别数组。
getCaterogies() {
return array('1' => 'short tempered', '2' => 'funny', '3' => 'visionary', ...);
}
我将索引存储在数据库中,并使用与之对应的数组的值到处显示值。。
$categories = $teacher->categories;
$category = $categories[$teacher->category];
我这样做是因为有一次有人建议我不要在数据库中存储作为状态的字符串,而是存储整数值,并将转换存储在数据库中或在ht模型中定义它。字符串的问题在于,它们在比较中更容易出现人为错误。也许是因为病例敏感性。
现在我面临的问题是,当在gridview中显示值时,我需要在值字段中写入2行,但这是一个表达式,外部变量也不需要。
我该如何为gridview工作?
您可以使用匿名函数作为值,它可以采用$row
、$data
参数,其中$row
包含行号(从零开始),$data
包含行的数据模型。
这样你就可以只在内部定义它。
$this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$dataProvider,
'columns'=>array(
array(
'name'=>'..',
'value'=>function($data,$row){
$categories = $teacher->categories;
return $categories[$data->category];
},
),
),
));
如果你想从外部使用它,你可以依赖PHP的use
:
$categories = $teacher->categories;
$this->widget('zii.widgets.grid.CGridView', array(
'dataProvider'=>$dataProvider,
'columns'=>array(
array(
'name'=>'..',
'value'=>function($data,$row) use ($categories){
return $categories[$data->category];
},
),
),
));
我个人推荐第二个,因为这样数组的计算将只进行一次,并且将在所有情况下使用。
您可以编写
$categories = $teacher->categories;
$category = $categories[$teacher->category];
一行:
$category = $teacher->categories[$teacher->category];
此外,我建议您使用另一种解决方案:
class ModelClass
{
const STATUS_SHORT_TEMPERED = 1;
const STATUS_FUNNY = 2;
const STATUS_VISIONARY = 3;
}
这允许您使用更具语义的
ModelClass::STATUS_FUNNY;
而不是语义较少的
2;
此外,您可以通过以下方式组成阵列:
getCaterogies() {
return array(
ModelClass::STATUS_FUNNY => 'status funny',
...
);
}
'urlCreator'=>函数($action,$model,$key,$index)使用($under_category){