Laravel 5 -Verträge: Ein tiefes Eintauchen in architektonische Verbesserungen und praktische Anwendung mit Twig
Laravel 5 führte eine signifikante architektonische Verbesserung ein: das Contracts -Paket. In diesem Artikel wird die Begründung dieser Änderung untersucht und zeigt einen praktischen Anwendungsfall, indem LaRavels Blade Templating Engine durch Symfony -Zweig ersetzt wird, wodurch die Macht der Verträge nutzt.
Schlüsselkonzepte:
Verständnisverständnisse:
Ein Vertrag ist im Wesentlichen eine Schnittstelle, die ein Verhalten angibt. Dies übereinstimmt mit objektorientierten Programmierprinzipien, bei denen Schnittstellen Methodensignaturen ohne Implementierungsdetails definieren. Der IOC -Container von Laravel erleichtert Bindungsschnittstellen (Verträge) an ihre Implementierungen. Zum Beispiel:
$this->app->bind('App\Contracts\EventPusher', 'App\Services\PusherEventPusher');
zu einem anderen Dienst (z. B. Fanout) umzuschalten, muss nur die Bindung ändern:
$this->app->bind('App\Contracts\EventPusher', 'App\Services\FanoutEventPusher');
Viele Core -Laravel -Dienste nutzen jetzt Verträge, um eine einfache Übersteuerung zu ermöglichen. Implementieren Sie beispielsweise den Illuminate/Mail
-Dienst, um den IlluminateContractsMail
-Vertrag zu ersetzen.
Ersetzen Sie die Klinge durch den Zweig unter Verwendung von Verträgen:
Die Standard -Templating -Engine von Laravel ist Blade. Dieses Beispiel zeigt, dass das Ersetzen durch Symfony -Zweig unter Verwendung von Verträgen ersetzt wird.
1. Paketdefinition (Composer.json):
{ "name": "whyounes/laravel5-twig", "description": "Twig for Laravel 5", "authors": [ { "name": "RAFIE Younes", "email": "younes.rafie@gmail.com" } ], "require": { "twig/twig": "1.18.*" }, "autoload": { "psr-0": { "RAFIE\": "src/" } } }
2. Service Provider anzeigen (TwigViewServiceProvider.php):
Dieser Anbieter registriert den Zweiglader und die Umgebung im Laravel -Service -Container.
// ... (Provider code as in original example) ...
3. Fabrik anzeigen (twigfactory.php):
Diese Fabrik implementiert und behandelt die Erstellung und das Rendern von Twig. IlluminateContractsViewFactory
// ... (Factory code as in original example) ...
4. Implementierung anzeigen (twigView.php):
Diese Klasse implementiert und fungiert als Container für die Zweigansicht und interagiert mit dem IlluminateContractsViewView
. TwigFactory
// ... (View code as in original example) ...
5. Registrierung von Dienstanbietern (config/app.php):
Registrieren Sie den TwigViewServiceProvider
und kommentieren
$this->app->bind('App\Contracts\EventPusher', 'App\Services\PusherEventPusher');
6. Verwenden von Twig in Routen (app/http/routes.php):
Jetzt können Sie Twig -Vorlagen verwenden:
$this->app->bind('App\Contracts\EventPusher', 'App\Services\FanoutEventPusher');
7. Twig -Vorlage (Ressourcen/Ansichten/Home.twig):
Eine einfache Zweig -Vorlage:
{ "name": "whyounes/laravel5-twig", "description": "Twig for Laravel 5", "authors": [ { "name": "RAFIE Younes", "email": "younes.rafie@gmail.com" } ], "require": { "twig/twig": "1.18.*" }, "autoload": { "psr-0": { "RAFIE\": "src/" } } }
Schlussfolgerung: Die Verträge von
Laravel 5 bieten einen leistungsstarken Mechanismus für die Erweiterung und Anpassung des Rahmens. Das Ersetzen von Blade durch Zweig zeigt die Vorteile dieses architektonischen Musters und führt zu saubereren, prüfbaren und flexibleren Anwendungen. Die konsistente API, die durch Verträge bereitgestellt wird, vereinfacht den Prozess und sorgt für die Wartbarkeit. Das vollständige Projekt finden Sie unter [Link zum Projekt].
häufig gestellte Fragen (FAQs):
(Der FAQS-Abschnitt aus der ursprünglichen Eingabe ist bereits gut geschrieben und umfassend. Hier sind keine Änderungen erforderlich.)Das obige ist der detaillierte Inhalt vonVerwenden Sie Laravel -Verträge, um ein Laravel 5 -Zweigpaket zu erstellen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!