我有个表是个树状分类表,up_id对应的是上级分类id,我就是想在表格里显示时,把up_id转换为上级分类的name,该怎么办呢?我觉得可以使用模型的获取器实现,但是不知道怎么用


表格数据的控制器方法是这样的
//返回分类列表数据
if(Request::isAjax()) {
$list = ModelTree::order(['up_id','sort','id'])
->paginate($this->request->get('limit', 20));
$data = [
'code' => 0,
'msg' => '正在请求中...',
'count' =>$list->count(),
'data' => $list->items()
];
return Json::create($data);
}Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号
问题解决了,哈哈
模型获取器写法
//上级分类名称获取器 public function getUpNameAttr($value,$data) { $list = Tree::field(['name'])->where('id','=',$data['up_id'])->find(); if($list) { return $list['name']; }else{ return '顶级分类'; } }控制器写法
//返回分类列表数据 if(Request::isAjax()) { $list = ModelTree::order(['up_id','sort','id']) ->paginate($this->request->get('limit', 20)); foreach ($list as $item) { $item->append(['up_name']); $item['up_name'] = $item->up_name; } $data = [ 'code' => 0, 'msg' => '正在请求中...', 'count' =>$list->count(), 'data' => $list->items() ]; return Json::create($data); }显示结果