php获取mc信息,thinkphp5 获取器的

获取器的作用是在获取数据的字段值后自动进行处理,例如,我们需要对状态值进行转换,可以使用:

1、数据库字段转换。

classUser extends Model

{publicfunction getStatusAttr($value)

{

$status= [-1=>'删除',0=>'禁用',1=>'正常',2=>'待审核'];return$status[$value];

}

}

数据表的字段会自动转换为驼峰法,一般status字段的值采用数值类型,我们可以通过获取器定义,自动

转换为字符串描述。

$user = User::get(1);

echo $user->status; //例如输出“正常”

如果同时需要状态值和状态名称

protectedfunction getSexAttr($value) {

$text= [1 => '男', 2 => '女', 3 => '未知'];return ['val' => $value, 'text' =>$text[$value]];

}

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

2、转换数据库不存在的字段,主要是这个用法

classUser extends Model

{publicfunction 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表为例吧

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

如果又需要用到值,又需要用到文本的情况

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值