## 门面 (Facade)
MixPHP 的门面具有如下功能:
- 为 **组件** 提供了一个静态调用接口,带来了更好的可读性与快速性,
- 同类型组件多源切换,如:多个 PDO、Redis 连接切换。
你可以为任何组件定义一个 `facade` 类。
## 核心门面类库
系统给内置的常用类库定义了 Facade 类库,可直接使用,包括:
| 组件 | 门面类 |
| --- | --- |
| app()->request | mix\facades\Request |
| app()->response | mix\facades\Response |
| app()->input | mix\facades\Input |
| app()->output | mix\facades\Output |
| app()->log | mix\facades\Log |
| app()->error | mix\facades\Error |
| app()->token | mix\facades\Token |
| app()->session | mix\facades\Session |
| app()->cookie | mix\facades\Cookie |
| app()->pdo | mix\facades\PDO |
| app()->redis | mix\facades\Redis |
## 自定义门面
为下面的组件定义一个门面:
~~~
// 组件配置
'components' => [
// 普通命名
'myComponent' => [
// 类路径
'class' => 'apps\index\components\MyComponent',
// 属性
'name' => '小花',
],
],
~~~
然后在 `apps\httpd\facades` 目录新增一个 `myComponent` 类文件。
~~~
<?php
namespace apps\httpd\facades;
use mix\base\Facade;
class myComponent extends Facade
{
// 获取实例
public static function getInstance()
{
return app()->myComponent;
}
}
~~~
## 门面使用
原本组件的调用:
~~~
app()->myComponent->foo();
~~~
门面类的调用,是不是简单很多。
~~~
myComponent::foo();
~~~
## 代码补全
自己创建的门面类是没有代码补全的,需要用户自己在注释中添加。
例如:
~~~
* @method emergency($message, array $context = []) static
* @method alert($message, array $context = []) static
* @method critical($message, array $context = []) static
* @method error($message, array $context = []) static
~~~
[>> 到 GitHub 查看门面注释 DEMO <<](https://github.com/mixstart/mixphp-framework/blob/v1/src/facades/Log.php)
## 同类型组件多源切换
系统提供的如下 Facade 类库具有多源切换功能:
| 门面类 |
| --- |
| mix\facades\PDO |
| mix\facades\Redis |
我们先看一下源码,看看于普通的有何不同:
[>> 到 GitHub 查看多源切换门面 <<](https://github.com/mixstart/mixphp-framework/blob/v1/src/facades/PDO.php)
- `getInstances` 方法返回一个具有多个组件的数组。
- `name` 方法可以通过名称切换当前使用的组件,这样就达到了切换数据库的效果。
当然我们实际使用中一定不可能去修改这个核心门面,只需写一个新的门面继承 `mix\facades\PDO` 类,并重写 `getInstances` 方法即可。
框架默认代码已经帮你继承好了,如下:
[>> 到 GitHub 查看门面 DEMO <<](https://github.com/mix-php/mix/blob/v1/apps/common/facades/PDO.php)
当需要频繁使用多个连接时,只需增加一个 pdo 组件:
~~~
// 数据库
'pdo' => [
// 类路径
'class' => 'mix\client\PDO',
// 数据源格式
'dsn' => env('DB_DSN'),
// 数据库用户名
'username' => env('DB_USERNAME'),
// 数据库密码
'password' => env('DB_PASSWORD'),
// 设置PDO属性: http://php.net/manual/zh/pdo.setattribute.php
'attribute' => [
// 设置默认的提取模式: \PDO::FETCH_OBJ | \PDO::FETCH_ASSOC
\PDO::ATTR_DEFAULT_FETCH_MODE => \PDO::FETCH_ASSOC,
],
],
// 数据库
'db1.pdo' => [
// 类路径
'class' => 'mix\client\PDO',
// 数据源格式
'dsn' => env('DB_DSN'),
// 数据库用户名
'username' => env('DB_USERNAME'),
// 数据库密码
'password' => env('DB_PASSWORD'),
// 设置PDO属性: http://php.net/manual/zh/pdo.setattribute.php
'attribute' => [
// 设置默认的提取模式: \PDO::FETCH_OBJ | \PDO::FETCH_ASSOC
\PDO::ATTR_DEFAULT_FETCH_MODE => \PDO::FETCH_ASSOC,
],
],
~~~
然后修改 `apps/common/facades/PDO` 类代码如下:
~~~
/**
* 获取实例集合
* @return array
*/
public static function getInstances()
{
return [
'default' => app()->pdo,
'db1' => app('db1')->pdo,
];
}
~~~
使用:
~~~
// 使用 default
/apps/common/facades/PDO::createCommand($sql)->queryAll();
// 使用 db1
/apps/common/facades/PDO::name('db1')->createCommand($sql)->queryAll();
~~~
- 欢迎使用 MixPHP
- 安装说明
- 常规安装
- 只安装命令行
- Apache/PHP-FPM安装
- 开发与调试
- 开发注意事项
- 调试与错误
- 基础架构
- 目录结构
- 目录设计
- URL访问
- 命名空间
- 自动加载
- 入口文件
- 框架核心
- Application
- 配置
- 对象
- 组件
- 门面
- 系统服务
- 中间件
- 验证器
- 验证器定义
- 验证规则
- 静态调用
- 模型
- 日志
- 命令行
- 简介
- 命令行开发常识
- 创建命令
- 执行与选项
- 控制台程序
- 守护程序
- HTTP 服务
- 简介
- 服务器
- 路由
- 请求
- 响应
- 控制器
- 视图
- Token
- Session
- Cookie
- 文件上传
- 图片处理
- 分页
- 验证码
- WebSocket 服务
- 简介
- 回调函数
- 消息处理器
- 客户端测试
- nginx代理
- 60s无消息断线
- 多进程
- ProcessPoolTaskExecutor
- 流水线模式
- 推送模式
- 在 Supervisor 中使用
- 协程
- 简介
- 如何开启协程
- HTTP 协程开发
- 命令行协程开发
- 客户端
- MySQL
- PDO
- PDOPersistent
- PDOMasterSlave
- PDOCoroutine
- Redis
- Redis
- RedisPersistent
- RedisCoroutine
- 外部工具库
- 简介
- think-orm
- psr-log
- 安全建议
- 常见问题
- 启动多个 HTTP 服务器
- 连接多个数据库
- 如何设置跨域
- mix-httpd service stop 无效
- No such file or directory
- 错误级别配置不生效
- 推进计划
- 文档历史