下面由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());
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()都是一樣打包全收。
以上是快來了解下TP6中的超級函數app()!的詳細內容。更多資訊請關注PHP中文網其他相關文章!