獲取器的作用是在獲取數據的字段值后自動進行處理,例如,我們需要對狀態值進行轉換,可以使用:
1、數據庫字段轉換。
class User extends Model { public function getStatusAttr($value) { $status = [-1=>'刪除',0=>'禁用',1=>'正常',2=>'待審核']; return $status[$value]; } }
數據表的字段會自動轉換為駝峰法,一般status字段的值采用數值類型,我們可以通過獲取器定義,自動
轉換為字符串描述。
$user = User::get(1); echo $user->status; // 例如輸出“正常”
如果同時需要狀態值和狀態名稱
protected function getSexAttr($value) { $text = [1 => '男', 2 => '女', 3 => '未知']; return ['val' => $value, 'text' => $text[$value]]; }
這種情況下,前台就可以直接使用了{$v.sex.val}是1,2,3值的格式。{$v.sex.text}就是男,女,未知的格式。
2、轉換數據庫不存在的字段,主要是這個用法
class User extends Model { public function getStatusTextAttr($value,$data) { $status = [-1=>'刪除',0=>'禁用',1=>'正常',2=>'待審核']; return $status[$data['status']]; } }
數據庫不存在這個status_text字段,但是如果在使用user對象取status_text 字段的話,就會自動調用這個轉換器。(這里需要注意的是第二個參數,$data是整個user對象數組)
$user = User::get(1);
echo $user->status_text; // 例如輸出“正常”
3、關聯其他表的字段構建user表里不存在的字段,其他表就以info表為例吧
protected function getHosNameAttr($value, $data) { $name = model('Info')->where('info_id', $data['id'])->value('hos_name'); return $name; }
在user表里構造了hos_name字段,這個例子很簡單,user表的主鍵id是info表的外鍵info_id,通過這個關系就可以將info里的字段映射到user表里,在后台只查詢user表的數據就能用hos_name了,可以省去兩表聯合查詢
如果又需要用到值,又需要用到文本的情況
protected function getArchivesAttr($value, $data) { $archiveid = model('Info')->where('info_id', $data['id'])->value('archives_id'); $archivename = model('Archives')->where('id', $archiveid)->value('name'); return ['val' => $archiveid, 'text' => $archivename]; }
此示例,在user表里構建了archives字段,val存的是info表的archives_id字段,text是archives_id對應的在表archives里的name字段。省去了三表聯合查詢,這樣在后台只需要查詢user表就可以在前台調用archives字段了。