zoukankan      html  css  js  c++  java
  • 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字段了。
  • 相关阅读:
    UOJ425【集训队作业2018】strings【分块,常数优化】
    UOJ444【集训队作业2018】二分图【构造,结论】
    各种类型转换为字符串类型(ToString())
    ADO.net数据绑定
    关于扫雷游戏学习笔记(二)
    关于扫雷游戏学习笔记(一)
    Luogu P2864 [USACO06JAN]树林The Grove(bfs)
    Luogu P1712 [NOI2016]区间(线段树)
    Luogu P2051 [AHOI2009]中国象棋(dp)
    Luogu P2577 [ZJOI2005]午餐(dp)
  • 原文地址:https://www.cnblogs.com/djiz/p/9817327.html
Copyright © 2011-2022 走看看