November 21, 2016 —John Koster
This article is part of a four part series all about Laravel facades. Each of the parts are listed below:
Facades are a convenient way to access Laravel's components. Each facade is bound to some component already registered in the service container. Facades are typically used to provide a simpler interface to an complex underlying subsystem. While some facades provide "shortcut" methods, most of Laravel's facades act like proxies by providing a static interface to an actual class instance.
All of the default facades are located within the Illuminate\Support\Facades
namespace and can be located within the vendor/laravel/framework/src/Illuminate/Support/Facades
directory. Every facade extends the abstract Facade
(Illuminate\Support\Facades\Facade
) class and must provide a getFacadeAccessor()
method which is defined to be protected.
The getFacadeAccessor()
method indicates what class or component should be resolved from the service container when the facade is accessed. All method calls are then redirected to that class instance. Laravel refers to this class instance as the facade root.
Some facades define additional static methods that may are not necessarily part of the underlying component or class. In these instances, the static method (that belongs to the facade) is called directly. One such example is the
Cookie
facade.
Facade roots are the class instance that is bound in the service container. For example, the Auth
facade redirects all method calls to an instance of Illuminate\Auth\AuthManager
, which the service container resolves with the auth
binding.
Each facade has an alias. An alias in PHP is just a shortcut to a longer class name. For example, when we use
something as something else, we are creating a class alias:
1<?php2use Some\ReallyReallyLongClassName as ShorterName;
In the above example ShorterName
is an alias of ReallyReallyLongClassName
. Laravel creates aliases for all of the facades automatically, and the entire list of them can be found in the aliases
array in the config/app.php
file. The aliases that Laravel creates are in the global namespace, which means that developers can write code that looks like this:
1<?php2 3namespace App\Http\Controllers;4 5use Input;6 7// Other code here.
instead of having to write code that references the full namespace:
1<?php2 3namespace App\Http\Controllers;4 5use Illuminate\Support\Facades\Input;6 7// Other code here.
Fully qualified names, such as Illuminate\Support\Facades\Input
are longer, but offer greater clarity on what class is being imported. At the end of the day, it comes down to personal preference.
∎