插件窝 干货文章 快来了解下TP6中的超级函数app()!

快来了解下TP6中的超级函数app()!

函数 获取 class 容器 411    来源:    2024-10-27

下面由thinkphp框架教程栏目给大家介绍tp6中的超级函数app(),希望对需要的朋友有所帮助!

tp6中的助手函数app(),是一个包含极广,涵盖极深,作用巨大的助手函数,他可以调用很多方法,也是很多助手函数 的集合。

首先这是在helper.php中定义的一个助手函数,我们来看一下:

if (!function_exists('app')) {
    /**
     * 快速获取容器中的实例 支持依赖注入
     * @param string $name        类名或标识 默认获取当前应用实例
     * @param array  $args        参数
     * @param bool   $newInstance 是否每次创建新的实例
     * @return object|App
     */
    function app(string $name = '', array $args = [], bool $newInstance = false)
    {
        return Container::getInstance()->make($name ?: App::class, $args, $newInstance);
    }}

这个函数如果你不带任何参数直接打印是这样的:
halt(app());
在这里插入图片描述

不带参数直接调用了think下的App类。

当你带上参数后它就调用了容器类Container。

容器类中装载了绝大多数我们常用的具有27种之多的依赖注入类。
如下:
在这里插入图片描述
在任何时候我们都可以往容器中注入新的类。
比如我们注入一个Upgrade类到容器中:

bind('settings','app\admin\controller\Upgrade');或者:bind('settings',Upgrade::class);或者:
Container::getInstance()->bind('settings', Upgrade::class)

如图:
在这里插入图片描述
调用容器中类:
调用方式:

app('settings')->upgradeTask($this->request);或:
Container::getInstance()->make('settings')->upgradeTask($this->request)

也就是app()助手函数不仅可以直接获取App类中的方法,还可以获取容器中所有的依赖注入类中的方法。容器是用来更方便的管理类依赖及运行依赖注入的工具。
依赖注入其实本质上是指在构造函数中对其他需要使用的类迅速实例化。
依赖注入的类统一由容器进行管理。

例如我们很多助手函数:

助手函数 描述
abort 中断执行并发送HTTP状态码
app 快速获取容器中的实例 支持依赖注入
bind    快速绑定对象实例
cache   缓存管理
class_basename  获取类名(不包含命名空间)class_uses_recursive   获取一个类里所有用到的traitconfig  获取和设置配置参数
cookie  Cookie管理
download    获取\think\response\Download对象实例
dump    浏览器友好的变量输出
env 获取环境变量
event   触发事件
halt    变量调试输出并中断执行
input   获取输入数据 支持默认值和过滤
invoke  调用反射执行callable 支持依赖注入
json    JSON数据输出
jsonp   JSONP数据输出
lang    获取语言变量值
parse_name  字符串命名风格转换
redirect    重定向输出
request 获取当前Request对象
response    实例化Response对象
session Session管理
token   生成表单令牌输出
trace   记录日志信息
trait_uses_recursive    获取一个trait里所有引用到的traiturl    Url生成
validate    实例化验证器
view    渲染模板输出
display 渲染内容输出
xml XML数据输出
app_path    当前应用目录
base_path   应用基础目录
config_path 应用配置目录
public_path web根目录
root_path   应用根目录
runtime_path    应用运行时目录

在APP()助手函数面前只能算是小弟,因为只用一个app()函数就可以替代绝大部分的助手函数。
举例:

例如我们调用配置文件:
config()
实际我们可以这样写:app('config')->get()又例如:request()->time() 可以写作:app('request')->time()

对于其他的助手函数,app()都是一样打包全收。