下面由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()都是一样打包全收。