Das Folgende ist eine Einführung in die Superfunktion app() in TP6 aus der Tutorial-Kolumne von thinkphp-Framework . Ich hoffe, dass es hilfreich sein wird Freunde in Not!
Die Assistentenfunktion app()
in tp6 ist Es enthält ein extrem breites Spektrum an Hilfsfunktionen mit extrem umfassender Abdeckung und enormen Auswirkungen. Es kann viele Methoden aufrufen und ist auch eine Sammlung vieler Hilfsfunktionen.
Zuallererst ist dies eine in helper.php definierte Hilfsfunktion:
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); }}
Wenn Sie diese Funktion direkt ohne Parameter ausdrucken, sieht sie so aus:
halt (app());
App
unter think ohne Parameter auf. Container
. Die Containerklasse enthält die meisten unserer häufig verwendeten Abhängigkeitsinjektionsklassen mit 27 Typen.
Wie folgt:
Wir können jederzeit neue Klassen in den Container einfügen.
Zum Beispiel fügen wir eine Upgrade-Klasse in den Container ein:
bind('settings','app\admin\controller\Upgrade');或者:bind('settings',Upgrade::class);或者: Container::getInstance()->bind('settings', Upgrade::class)
Wie in der Abbildung gezeigt:
Rufen Sie die Klasse im Container auf:
Aufrufmethode:
app('settings')->upgradeTask($this->request);或: Container::getInstance()->make('settings')->upgradeTask($this->request)
Das heißt, die Hilfsfunktion app() kann nicht nur die Methoden in der App-Klasse direkt abrufen, sondern auch die Methoden in allen Abhängigkeitsinjektionsklassen im Container. Container sind Tools, mit denen Klassenabhängigkeiten bequemer verwaltet und Abhängigkeitsinjektionen ausgeführt werden können.
Abhängigkeitsinjektion bezieht sich im Wesentlichen auf die schnelle Instanziierung anderer Klassen, die im Konstruktor verwendet werden müssen.
Abhängigkeitsinjizierte Klassen werden vom Container einheitlich verwaltet.
Zum Beispiel haben wir viele Assistentenfunktionen:
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 应用运行时目录
kann nur als der jüngere Bruder vor der APP()-Assistentenfunktion angesehen werden, weil Es wird nur eine app()-Funktion verwendet. Ersetzt die meisten Hilfsfunktionen.
Beispiel:
例如我们调用配置文件: config() 实际我们可以这样写:app('config')->get()又例如:request()->time() 可以写作:app('request')->time()
Für andere Hilfsfunktionen packt app() sie alle auf die gleiche Weise.
Das obige ist der detaillierte Inhalt vonKommen Sie und lernen Sie die Superfunktion app() in TP6 kennen!. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!