1. 程式人生 > >thinkphp5 獲取器的

thinkphp5 獲取器的

獲取器的作用是在獲取資料的欄位值後自動進行處理,例如,我們需要對狀態值進行轉換,可以使用:

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欄位了。