门面

最后更新于:2022-04-02 07:48:29

## 门面(`Facade`) 门面为容器中的(动态)类提供了一个静态调用接口,相比于传统的静态方法调用, 带来了更好的可测试性和扩展性,你可以为任何的非静态类库定义一个`facade`类。 >[info] 系统已经为大部分核心类库定义了`Facade`,所以你可以通过`Facade`来访问这些系统类,当然也可以为你的应用类库添加静态代理。 下面是一个示例,假如我们定义了一个`app\common\Test`类,里面有一个`hello`动态方法。 ~~~ hello('thinkphp'); // 输出 hello,thinkphp ~~~ 接下来,我们给这个类定义一个静态代理类`app\facade\Test`(这个类名不一定要和`Test`类一致,但通常为了便于管理,建议保持名称统一)。 ~~~ [danger] 说的直白一点,Facade功能可以让类无需实例化而直接进行静态方式调用。 ## 核心`Facade`类库 系统给内置的常用类库定义了`Facade`类库,包括: | (动态)类库 | Facade类 | | --- | --- | | think\\App | think\\facade\\App | | think\\Cache | think\\facade\\Cache | | think\\Config | think\\facade\\Config | | think\\Cookie | think\\facade\\Cookie | | think\\Db | think\\facade\\Db | | think\\Env | think\\facade\\Env | | think\\Event | think\\facade\\Event | | think\\Filesystem| think\\facade\\Filesystem | | think\\Lang | think\\facade\\Lang | | think\\Log | think\\facade\\Log | | think\\Middleware | think\\facade\\Middleware | | think\\Request | think\\facade\\Request | | think\\Route | think\\facade\\Route | | think\\Session | think\\facade\\Session | | think\\Validate | think\\facade\\Validate | | think\\View| think\\facade\\View| 所以你无需进行实例化就可以很方便的进行方法调用,例如: ~~~ use think\facade\Cache; Cache::set('name','value'); echo Cache::get('name'); ~~~ 在进行依赖注入的时候,请不要使用`Facade`类作为类型约束,而是建议使用原来的动态类,下面是错误的用法: ~~~ controller(); } } ~~~ 和下面的作用是一样的 ~~~ [danger] 一定要注意两种方式的`use`引入类库的区别
';