首页  >  问答  >  正文

tp5.1如何使用获取器添加自定义字段?

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

QQ图片20200208110805.png

QQ图片20200208110814.png

表格数据的控制器方法是这样的

//返回分类列表数据
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);
}


清风清风1738 天前1416

全部回复(1)我来回复

  • 清风

    清风2020-02-08 13:02:26

    问题解决了,哈哈

    模型获取器写法

    //上级分类名称获取器
    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);
    }

    显示结果

    2020-02-08_130345.jpg

    回复
    0
  • 取消回复