ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
## 数组访问 |版本|新增功能| |---|---| |5.0.10|增加`removeRelation`方法去除所有的关联属性| |5.0.5|`hidden`、`visible`和`append`方法支持关联属性| |5.0.4|增加`appendRelationAttr`方法追加关联模型的属性| 模型对象支持数组方式访问,例如: ~~~ $user = User::find(1); echo $user->name ; // 有效 echo $user['name'] // 同样有效 $user->name = 'thinkphp'; // 有效 $user['name'] = 'thinkphp'; // 同样有效 $user->save(); ~~~ ## 转换为数组 可以使用`toArray`方法将当前的模型实例输出为数组,例如: ~~~ $user = User::find(1); dump($user->toArray()); ~~~ 支持设置不输出的字段属性: ~~~ $user = User::find(1); dump($user->hidden(['create_time','update_time'])->toArray()); ~~~ 数组输出的字段值会经过获取器的处理,也可以支持追加其它获取器定义(不在数据表字段列表中)的字段,例如: ~~~ $user = User::find(1); dump($user->append(['status_text'])->toArray()); ~~~ 支持设置允许输出的属性,例如: ~~~ $user = User::find(1); dump($user->visible(['id','name','email'])->toArray()); ~~~ 如果是数据集查询的话有两种情况,由于默认的数据集返回结果的类型是一个数组,因此无法调用`toArray`方法,必须先转成数据集对象然后再使用`toArray`方法,系统提供了一个`collection`助手函数实现数据集对象的转换,代码如下: ~~~ $list = User::all(); if($list) { $list = collection($list)->toArray(); } ~~~ 如果设置了模型的数据集返回类型的话,则可以简化使用 ~~~ <?php namespace app\index\model; use think\Model; class User extends Model { protected $resultSetType = 'collection'; } ~~~ 然后就可以直接使用 ~~~ $list = User::all(); $list = $list->toArray(); ~~~ ## 追加关联模型的属性(`V5.0.4+`) `V5.0.4+`版本开始,支持追加一对一关联模型的属性到当前模型,例如: ~~~ $user = User::find(1); dump($user->appendRelationAttr('profile',['email','nickname'])->toArray()); ~~~ `profile`是关联定义方法名,`email`和`nickname`是`Profile`模型的属性。 ## 支持关联属性(`V5.0.5+`) 模型的`visible`、`hidden`和`append`方法支持关联属性操作,例如: ~~~ $user = User::get(1,'profile'); // 隐藏profile关联属性的email属性 dump($user->hidden(['profile'=>['email']])->toArray()); // 或者使用 dump($user->hidden(['profile.email'])->toArray()); ~~~ `hidden`、`visible`和`append`方法同样支持数据集对象。