依赖注入本质上是指类的依赖通过构造器完成自动注入。
例如:在控制器构造方法或普通方法中一旦对参数进行对象类型约束则会自动触发依赖注入,由于访问控制器的参数都来自于URL请求,普通变量就是通过参数绑定自动获取,对象变量则是通过依赖注入生成
依赖注入:即允许通过类的方法传递对象的能力,并且限制了对象的类型(约束),而传递对象的背后那个类被自动绑定并且实例化了,这就是依赖注入
依赖注入的类统一由容器管理的,大多数情况下是自动绑定和自动实例化的
如果想手动来完成绑定和实例化,可以使用 bind() 和 app() 助手函数实现
// 绑定类库标识,这个标识具有唯一性,以便快速调用
bind('one', \app\model\User::class);
// 快速调用并且自动实例化对象,类库标识严格区分大小写
app('one');
// 第二参数用于传参,
// 自动实例化对象的方式默认使用单例模式,第三参数为true时调用会重新实例化
app('one', [], true);
// 也可以直接绑定一个类到容器中并自动实例化
app(\app\model\User::class);
// 使用 bind([]) 可以批量绑定
// 不同系统有专门提供批量绑定的文件 app/provider.php
bind([
'user' => \app\model\User::class,
'admin' => \app\model\Admin::class,
]);
框架文件 app/provider.php 用于定义容器类, 将类绑定到容器中
自己封装的一些类文件可以通过该文件将类绑定到容器中, 以便快速调用
<?php
use app\ExceptionHandle;
use app\Request;
// 容器Provider定义文件
return [
'think\Request' => Request::class,
'think\exception\Handle' => ExceptionHandle::class,
// 扩展类库
'math' => Math::class,
'layui' => Layui::class,
];
快速调用
app('layui')->table('用户列表', 10, $data);