## 模型輸出
模型數據的模板輸出可以直接把模型對象實例賦值給模板變量,在模板中可以直接輸出,例如:
~~~
<?php
namespace app\controller;
use app\model\User;
use think\facade\View;
class Index
{
public function index()
{
$user = User::find(1);
View::assign('user', $user);
return View::fetch();
}
}
~~~
在模板文件中可以使用
~~~
{$user.name}
{$user.email}
~~~
>[info] 模板中的模型數據輸出一樣會調用獲取器。
## 數組轉換
可以使用`toArray`方法將當前的模型實例輸出為數組,例如:
~~~
$user = User::find(1);
dump($user->toArray());
~~~
支持設置不輸出的字段屬性:
~~~
$user = User::find(1);
dump($user->hidden(['create_time','update_time'])->toArray());
~~~
數組輸出的字段值會經過獲取器的處理,如果不在數據表字段列表中的字段屬性需要輸出,必須使用`append`方法附加屬性,例如:
~~~
$user = User::find(1);
dump($user->append(['status_text'])->toArray());
~~~
支持設置允許輸出的屬性,例如:
~~~
$user = User::find(1);
dump($user->visible(['id','name','email'])->toArray());
~~~
對于數據集結果一樣可以直接使用(包括`append`、`visible`和`hidden`方法)
~~~
$list = User::select();
$list = $list->toArray();
~~~
可以在查詢之前定義`hidden`/`visible`/`append`方法,例如:
~~~
dump(User::where('id',10)->hidden(['create_time','update_time'])->append(['status_text'])->find()->toArray());
~~~
注意,必須要首先調用一次Db類的方法后才能調用`hidden`/`visible`/`append`方法。
## JSON序列化
可以調用模型的`toJson`方法進行`JSON`序列化,`toJson`方法的使用和`toArray`一樣。
~~~
$user = User::find(1);
echo $user->toJson();
~~~
可以設置需要隱藏的字段,例如:
~~~
$user = User::find(1);
echo $user->hidden(['create_time','update_time'])->toJson();
~~~
或者追加其它的字段(該字段必須有定義獲取器):
~~~
$user = User::find(1);
echo $user->append(['status_text'])->toJson();
~~~
設置允許輸出的屬性:
~~~
$user = User::find(1);
echo $user->visible(['id','name','email'])->toJson();
~~~
模型對象可以直接被JSON序列化,例如:
~~~
echo json_encode(User::find(1));
~~~
輸出結果類似于:
~~~
{"id":"1","name":"","title":"","status":"1","update_time":"1430409600","score":"90.5"}
~~~
如果直接`echo` 一個模型對象會自動調用模型的`toJson`方法輸出,例如:
~~~
echo User::find(1);
~~~
輸出的結果和上面是一樣的。
- 簡介
- 數據庫配置
- 分布式數據庫
- 查詢構造器
- 查詢數據
- 新增數據
- 更新數據
- 刪除數據
- 鏈式操作
- Where
- Table
- Alias
- Field
- Strict
- Limit
- Page
- Order
- Group
- Having
- Join
- Union
- Distinct
- Lock
- Cache
- Comment
- FetchSql
- Force
- Partition
- Replace
- FailException
- Extra
- Duplicate
- Sequence
- Procedure
- View
- 聚合查詢
- 分頁查詢
- 時間查詢
- 高級查詢
- 子查詢
- 原生查詢
- 事務操作
- 存儲過程
- 查詢事件
- JSON字段
- 模型
- 定義
- 新增
- 更新
- 刪除
- 查詢
- 查詢范圍
- 只讀字段
- JSON字段
- 自動時間寫入
- 獲取器
- 修改器
- 搜索器
- 類型轉換
- 模型輸出
- 模型事件
- 虛擬模型
- 關聯
- 一對一關聯
- 一對多關聯
- 遠程一對多
- 遠程一對一
- 多對多關聯
- 多態一對多
- 多態一對一
- 關聯預載入
- 關聯統計
- 關聯輸出
- SQL監聽
- 緩存機制
- 字段緩存
- 查詢緩存
- 擴展
- 自定義查詢類
- 自定義數據庫驅動