Facade는 실제로 컨테이너에 있는 클래스의 정적 프록시입니다. 이를 통해 컨테이너에 저장된 모든 개체의 메서드를 정적으로 호출할 수 있습니다. 다음 글은 Laravel에서 Facade의 로딩 과정과 원리에 대한 관련 정보를 주로 소개합니다.
공식 문서에 제공된 정의
"Facade는 애플리케이션의 서비스 컨테이너에 "정적" 인터페이스를 제공합니다. Laravel에는 대부분의 기능에 대한 액세스를 제공하는 많은 Facade가 포함되어 있습니다. Laravel Facades는 실제로 서비스 컨테이너의 기본 클래스에 대한 "정적 프록시"입니다. 전통적인 정적 방법과 비교하여 사용 시 더 유연하고, 테스트하기 쉽고, 더 우아한 구문을 제공할 수 있습니다. "
객체의 특정 메소드에 액세스하기 위해 긴 네임스페이스 목록을 사용하거나 객체를 인스턴스화할 필요가 없습니다.
use Config; class Test { public function index() { return Config::get('app.name'); } }
Facade 시작 및 등록
Facade 시작 부팅은 IlluminateFoundationBootstrapRegisterFacades에 등록됩니다.
public function bootstrap(Application $app) { Facade::clearResolvedInstances(); Facade::setFacadeApplication($app); AliasLoader::getInstance(array_merge( $app->make('config')->get('app.aliases', []), $app->make(PackageManifest::class)->aliases() ))->register(); }
The 기본 별칭 구성은 앱 구성 파일 아래의 별칭에서 읽혀집니다. PackageManifest는 laravel 5.5의 새로운 패키지 자동 검색 규칙입니다. 여기서는 당분간 PackageManifest 패키지에서 제공하는 별칭을 고려하지 않습니다. . 다음 형식의 배열:
"App" => "Illuminate\Support\Facades\App" "Artisan" => "Illuminate\Support\Facades\Artisan" "Auth" => "Illuminate\Support\Facades\Auth" "Blade" => "Illuminate\Support\Facades\Blade" ...
/** * Prepend the load method to the auto-loader stack. * * @return void */ protected function register() { if (! $this->registered) { spl_autoload_register([$this, 'load'], true, true); $this->registered = true; } }
spl_autoload_register를 정의할 때 이 매개변수가 true로 전달되면 spl_autoload_register()는 대기열의 끝이 아닌 대기열의 헤드에 함수를 추가합니다. . 이 기능을 통해 자동 로딩을 우선시합니다) 즉,
<?php use Config; use App\User; class Test { public function index() { Config::get('app.name'); new User(); } }
public function load($alias) { if (isset($this->aliases[$alias])) { return class_alias($this->aliases[$alias], $alias); } }
class foo { } class_alias('foo', 'bar'); $a = new foo; $b = new bar; // the objects are the same var_dump($a == $b, $a === $b); //true var_dump($a instanceof $b); //false // the classes are the same var_dump($a instanceof foo); //true var_dump($a instanceof bar); //true var_dump($b instanceof foo); //true var_dump($b instanceof bar); //true
Facade loading
Facade를 사용할 때 다음과 같습니다.
<?php use Config; class Test { public function index() { Config::get('app.name'); } }
<?php use Illuminate\Support\Facades\Config; class Test { public function index() { Config::get('app.name'); } }
<?php public static function __callStatic($method, $args) { $instance = static::getFacadeRoot(); if (! $instance) { throw new RuntimeException('A facade root has not been set.'); } return $instance->$method(...$args); }
protected static function getFacadeAccessor() { return 'config'; }
getFacadeAccessor() </code의 반환 값을 기반으로 컨테이너에서 해당 실제 열 개체를 검색합니다. >. <p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">public static function getFacadeRoot()
{
$name = static::getFacadeAccessor();
if (is_object($name)) {
return $name;
}
if (isset(static::$resolvedInstance[$name])) {
return static::$resolvedInstance[$name];
}
return static::$resolvedInstance[$name] = static::$app[$name];
}</pre><div class="contentsignin">로그인 후 복사</div></div></p>config 열이 APP 컨테이너<p><div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false"><?php
//Illuminate\Foundation\Bootstrap/LoadConfiguration
$app->instance(&#39;config&#39;, $config = new Repository($items));</pre><div class="contentsignin">로그인 후 복사</div></div><code>getFacadeAccessor()
的返回值,从容器从取出对应的实列对象。rrreee由于 APP 容器中已经注册过 config 的实列
rrreee所以 Config::get('app.name', 'dafault)
实际访问的是 Repository 实列的 get('app.name', 'default')
에 등록되었으므로 Config::get('app.name', 'dafault)
는 실제로 Repository 열 get( 'app.name', 'default')
메소드.
더 많은 관련 지식을 알고 싶으시다면 PHP 중국어 홈페이지를 방문해주세요! !
위 내용은 Laravel의 Facade란 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!