TP5模型常用知识点

本文详细介绍了TP5框架中模型获取器的使用,包括如何定义获取器以转换数据表字段值,如将status数值转为状态描述,以及如何创建不存在的字段映射其他表的字段,减少联合查询。通过示例展示了如何利用获取器实现一维数组和二维数组的转换,以及关联其他表的字段,提高查询效率和代码可读性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.【模型——获取器】获取器

(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; // 例如输出“正常”

 

(2)tp5的获取器功能很强大,一下子就喜欢上了,你可以在模块里任意定义表里不存在的字段,在前台调用很方便。话不多说直接上demo:

  1.命名规则   get + 属性名的驼峰命名+ Attr

  直接就能在model里定义:(本示例在UserModel里定义的(User.php文件))

  eg1:

  protected function getSexAttr($value) {
    $text = [1 => '男', 2 => '女', 3 => '未知'];
    return $text[$value];
  }

  此情景下user表里是存在sex字段的,sex的值为1,2,3三种情况。这个获取器的作用在于,后台获取user表的list后,sex值仍为1,2,3。前台循环调用的时候就可以用{volist name="list" id="v" key="k"}{$v.sex}{/volist} 此时的{$v.sex}就对应成男,女,未知。

  2.针对前台需要用到sex值1,2,3同时也要用到文本值男,女,未知的时候,这个获取器就有局限性了,此时,小伙伴们很容易想到,定义两个获取器,一个存1,2,3另一个存男,女,未知。ok,这个方法是可行的,在这里简单介绍一下我想到的方法,定义一个获取器存二维数组。

  eg2:

  protected function getSexAttr($value) {
    $text = [1 => '男', 2 => '女', 3 => '未知'];
    return ['val' => $value, 'text' => $text[$value]];
  }

  这种情况下,前台就可以直接使用了{$v.sex.val}是1,2,3值的格式。{$v.sex.text}就是男,女,未知的格式。

  看到这里,相信小伙伴们已经蠢蠢欲动了吧,这还不止呢,接下来介绍一下,定义不存在的字段,映射其他表的字段。就可以应用到项目中了。

  3.关联其他表的字段构建user表里不存在的字段,其他表就以info表为例吧

  eg3:

  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了,可以省去两表联合查询

  4.如果又需要用到值,又需要用到文本的情况,就可以用第二个例子的思路了。

  eg4:

  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字段了。

  怎样,是不是你也不自觉得喜欢上了tp5的获取器,尽情的使用吧,在使用过程中,相信你会有更多感悟的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值