tp5.1如何使用獲取器添加自定義字段?
問題描述
我有個表是個樹狀分類表,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);}
問題解答
回答1:問題解決了,哈哈
模型獲取器寫法
//上級分類名稱獲取器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);}
顯示結果
相關文章:
1. mysql - 這條聯合sql語句哪里錯了2. mysql優化 - 關于mysql分區3. 請教各位大佬,瀏覽器點 提交實例為什么沒有反應4. java - Atom中文問題5. java - MySQL中,使用聚合函數+for update會鎖表嗎?6. css3 - 這個形狀使用CSS怎么寫出來?7. javascript - 為什么這個點擊事件需要點擊兩次才有效果8. node.js - 在vuejs-templates/webpack中dev-server.js里為什么要exports readyPromise?9. javascript - ionic2 input autofocus 電腦成功,iOS手機鍵盤不彈出10. java - C語言算法題-韓信點兵 求解?