Was ist Fassade in Laravel?
Facade ist eigentlich ein statischer Proxy einer Klasse in einem Container. Es ermöglicht Ihnen, jede Methode jedes im Container gespeicherten Objekts statisch aufzurufen. Der folgende Artikel enthält hauptsächlich relevante Informationen zum Ladevorgang und zum Prinzip von Facade in Laravel. Freunde in Not können darauf zurückgreifen.
Die Definition im offiziellen Dokument
„Fassaden bieten eine „statische“ Schnittstelle. Laravel verfügt über viele Fassaden, die den Zugriff auf die meisten Funktionen ermöglichen. Laravel-Fassaden sind eigentlich „statische Proxys“ für die zugrunde liegenden Klassen im Service-Container. Im Vergleich zu herkömmlichen statischen Methoden können sie bei ihrer Verwendung eine flexiblere, einfacher zu testende und elegantere Syntax bieten. ”
Sie müssen keine lange Liste von Namespaces verwenden oder das Objekt instanziieren, um auf die spezifischen Methoden des Objekts zuzugreifen.
use Config; class Test { public function index() { return Config::get('app.name'); } }
Fassadenstart und Registrierung
Der Startup-Boot von Facade wird in IlluminateFoundationBootstrapRegisterFacades registriert
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(); }
Die Standard-Alias-Konfiguration wird aus den Aliasen unter der App-Konfigurationsdatei gelesen, und das PackageManifest ist 5.5 verfügt über neue automatische Erkennungsregeln für Pakete.
Unter diesen gibt array_merge ein Array im folgenden Format zurück:
"App" => "Illuminate\Support\Facades\App" "Artisan" => "Illuminate\Support\Facades\Artisan" "Auth" => "Illuminate\Support\Facades\Auth" "Blade" => "Illuminate\Support\Facades\Blade" ...
Der obige Code wird für das automatische Laden über AliasLoader registriert. Der Kern ist PHPs spl_autoload_register. Nach Abschluss der Registrierung werden alle nachfolgenden Nutzungsklassen automatisch geladen >
Hinweis:/** * 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; } }
Bei der Definition von spl_autoload_register wird der letzte Parameter als wahr übergeben. Wenn dieser Parameter wahr ist, fügt spl_autoload_register() die Funktion der Warteschlange hinzu, nicht dem Ende die Warteschlange (das automatische Laden wird zuerst durch diese Funktion abgeschlossen)
Mit anderen Worten: Egal welche spezifische Klasse wir verwenden (AppUser) oder Alias (Config), Das automatische Laden wird zuerst durch die Ladefunktion abgeschlossen. Wenn die Funktion false zurückgibt, wird das automatische Laden durch andere automatische Ladefunktionen (z. B. Composer psr-4) abgeschlossen. In der Lademethode von AliasLoader wird hauptsächlich die Funktion class_alias verwendet Automatisches Laden von Aliasen implementieren
Hier ist ein offizielles Beispiel für class_alias:
<?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); } }
Wann Wir verwenden die Fassade, wie zum Beispiel:
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
Die IlluminateSupportFacadesConfig-Klasse wird tatsächlich geladen (da wir class_alias registriert haben), was durchaus der Fall ist. In:
Alle Fassaden erben von der IlluminateSupportFacadesFacade-Klasse und eine __callStatic-Methode sind in dieser Basisklasse definiert, sodass wir die Facade problemlos verwenden können (ohne Instanziierung).
<?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); }
String-Typ string-like ( wie z. B. AppServiceSomeService)
Objektspezifisches Instanziierungsobjekt
Schließungsverschluss
wie z Die getFacadeAccessor-Methode von Config Facade lautet wie folgt:
- Die getFacadeRoot-Methode ruft das entsprechende reale Spaltenobjekt aus dem Container basierend auf dem Rückgabewert von
ab.
protected static function getFacadeAccessor() { return 'config'; }
greift sie tatsächlich auf die Methode getFacadeAccessor()
der Repository-Instanzspalte zu.
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]; }
PHP-Website für Chinesisch
! !<?php //Illuminate\Foundation\Bootstrap/LoadConfiguration $app->instance('config', $config = new Repository($items));
Das obige ist der detaillierte Inhalt vonWas ist Fassade in Laravel?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen



Datenbankoperationen in PHP werden durch ORM vereinfacht, das Objekte in relationalen Datenbanken abbildet. EloquentORM in Laravel ermöglicht Ihnen die Interaktion mit der Datenbank mithilfe einer objektorientierten Syntax. Sie können ORM verwenden, indem Sie Modellklassen definieren, Eloquent-Methoden verwenden oder in der Praxis ein Blog-System erstellen.

Analyse des PHP-Unit-Test-Tools: PHPUnit: Geeignet für große Projekte, bietet umfassende Funktionalität und ist einfach zu installieren, kann jedoch ausführlich und langsam sein. PHPUnitWrapper: geeignet für kleine Projekte, einfach zu verwenden, optimiert für Lumen/Laravel, verfügt jedoch über eingeschränkte Funktionalität, bietet keine Code-Coverage-Analyse und hat begrenzte Community-Unterstützung.

Die neuesten Versionen von Laravel 9 und CodeIgniter 4 bieten aktualisierte Funktionen und Verbesserungen. Laravel9 übernimmt die MVC-Architektur und bietet Funktionen wie Datenbankmigration, Authentifizierung und Template-Engine. CodeIgniter4 nutzt die HMVC-Architektur, um Routing, ORM und Caching bereitzustellen. In Bezug auf die Leistung sorgen das auf Dienstanbietern basierende Designmuster von Laravel9 und das leichte Framework von CodeIgniter4 für eine hervorragende Leistung. In praktischen Anwendungen eignet sich Laravel9 für komplexe Projekte, die Flexibilität und leistungsstarke Funktionen erfordern, während CodeIgniter4 für schnelle Entwicklung und kleine Anwendungen geeignet ist.

Laravel – Artisan Commands – Laravel 5.7 bietet eine neue Möglichkeit, neue Befehle zu behandeln und zu testen. Es enthält eine neue Funktion zum Testen von Handwerkerbefehlen und die Demonstration wird unten erwähnt?

Vergleichen Sie die Datenverarbeitungsfunktionen von Laravel und CodeIgniter: ORM: Laravel verwendet EloquentORM, das eine relationale Klassen-Objekt-Zuordnung bereitstellt, während CodeIgniter ActiveRecord verwendet, um das Datenbankmodell als Unterklasse von PHP-Klassen darzustellen. Abfrage-Builder: Laravel verfügt über eine flexible verkettete Abfrage-API, während der Abfrage-Builder von CodeIgniter einfacher und Array-basiert ist. Datenvalidierung: Laravel bietet eine Validator-Klasse, die benutzerdefinierte Validierungsregeln unterstützt, während CodeIgniter über weniger integrierte Validierungsfunktionen verfügt und eine manuelle Codierung benutzerdefinierter Regeln erfordert. Praxisfall: Beispiel einer Benutzerregistrierung zeigt Lar

Bei der Auswahl eines Frameworks für große Projekte haben Laravel und CodeIgniter jeweils ihre eigenen Vorteile. Laravel ist für Anwendungen auf Unternehmensebene konzipiert und bietet modularen Aufbau, Abhängigkeitsinjektion und einen leistungsstarken Funktionsumfang. CodeIgniter ist ein leichtes Framework, das sich eher für kleine bis mittelgroße Projekte eignet und Wert auf Geschwindigkeit und Benutzerfreundlichkeit legt. Für große Projekte mit komplexen Anforderungen und einer großen Anzahl von Benutzern sind die Leistung und Skalierbarkeit von Laravel besser geeignet. Für einfache Projekte oder Situationen mit begrenzten Ressourcen sind die leichten und schnellen Entwicklungsfunktionen von CodeIgniter idealer.

Für Anfänger bietet CodeIgniter eine sanftere Lernkurve und weniger Funktionen, deckt aber die Grundbedürfnisse ab. Laravel bietet einen größeren Funktionsumfang, weist jedoch eine etwas steilere Lernkurve auf. In Bezug auf die Leistung schneiden sowohl Laravel als auch CodeIgniter gut ab. Laravel verfügt über eine umfangreichere Dokumentation und aktive Community-Unterstützung, während CodeIgniter einfacher und leichtgewichtiger ist und über starke Sicherheitsfunktionen verfügt. Im praktischen Fall der Erstellung einer Blogging-Anwendung vereinfacht EloquentORM von Laravel die Datenmanipulation, während CodeIgniter mehr manuelle Konfiguration erfordert.

Leitfaden zum Testen von PHP-Einheiten und -Integrationen Unit-Tests: Konzentrieren Sie sich auf eine einzelne Code- oder Funktionseinheit und verwenden Sie PHPUnit, um Testfallklassen zur Überprüfung zu erstellen. Integrationstests: Achten Sie darauf, wie mehrere Codeeinheiten zusammenarbeiten, und verwenden Sie die Methoden setUp() und TearDown() von PHPUnit, um die Testumgebung einzurichten und zu bereinigen. Praktischer Fall: Verwenden Sie PHPUnit, um Unit- und Integrationstests in Laravel-Anwendungen durchzuführen, einschließlich der Erstellung von Datenbanken, dem Starten von Servern und dem Schreiben von Testcode.
