/**
* 字段映射,配合映射字典 $field_map
* [[目标字段$field, 检索模型$class, 检索字段$from(默认id), 取出字段$to(默认name)]]
*
* 例如 ["rid", Role::class, "id", "name"]
* Role表检索 id=$data['rid'],取出 name,最后 $data['rid_t']=name
*/
function fetchScalarByField($data, $field_map)
{
foreach ($field_map as $v) {
$field = array_shift($v);
$class = array_shift($v);
$from = $v ? array_shift($v) : 'id';
$to = $v ? array_shift($v) : 'name';
if (isset($data[$field])) {
$data[$field . '_t'] = $class::fetchScalar([$from => $data[$field]], $to);
}
}
return $data;
}
使用方法
// 示例数据
$data = [
'rid' => 1,
'cur_step' => 1,
'other' => 1,
];
// 组织映射字典
$field_map = [
['rid', RoleModel::class],
['cur_step', StepModel::class, 'step']
];
$data = fetchScalarByField($data, $field);
return json_encode($data);
// 输出
$data = [
'rid' => 1,
'rid_t' => '管理员',
'cur_step' => 1,
'cur_step_t' => '第一步',
'other' => 1,
];