Laravel5.5 视图 - 创建视图和数据传递示例(2)
视图 Composer
视图 Composer 是当视图被渲染时的回调函数或类方法。
如果你有一些数据需要在视图每次渲染时都做绑定,可以使用视图 Composer 将逻辑组织到一个单独的地方。
在本例中,首先要在某个服务提供者中注册视图 Composer,我们将会使用 View 门面来访问 Illuminate\Contracts\View\Factory 的底层实现,记住,Laravel 不会包含默认的视图 Composer 目录,我们可以按照自己的喜好组织其路径,例如可以创建一个 app/Http/ViewComposers 目录:
<?php namespace App\Providers; use Illuminate\Support\Facades\View; use Illuminate\Support\ServiceProvider; class ComposerServiceProvider extends ServiceProvider { /** * 在容器中注册绑定. * * @return void */ public function boot() { // 使用基于类方法的 composers... View::composer( 'profile', 'App\Http\ViewComposers\ProfileComposer' ); // 使用基于回调函数的 composers... View::composer('dashboard', function ($view) {}); } /** * 注册服务提供者. * * @return void */ public function register() { // } }
注:如果创建一个新的服务提供者来包含视图 Composer 注册,需要添加该服务提供者到配置文件 config/app.php 的 providers 数组中。
现在我们已经注册了视图 Composer,每次 profile 视图被渲染时都会执行 ProfileComposer@compose 方法,接下来我们来定义该 Composer 类:
<?php namespace App\Http\ViewComposers; use Illuminate\View\View; use Illuminate\Repositories\UserRepository; class ProfileComposer { /** * 用户仓库实现. * * @var UserRepository */ protected $users; /** * 创建一个新的属性composer. * * @param UserRepository $users * @return void */ public function __construct(UserRepository $users) { // 依赖注入通过服务容器自动解析... $this->users = $users; } /** * 绑定数据到视图. * * @param View $view * @return void */ public function compose(View $view) { $view->with('count', $this->users->count()); } }
视图被渲染前,Composer 类的 compose 方法被调用,同时 Illuminate\View\View 实例被注入该方法,从而可以使用其 with 方法来绑定数据到视图。
注:所有视图 Composer 都通过服务容器被解析,所以你可以在 Composer 类的构造函数中声明任何你需要的依赖。
添加 Composer 到多个视图
你可以传递视图数组作为 composer 方法的第一个参数来一次性将视图 Composer 添加到多个视图:
View::composer( ['profile', 'dashboard'], 'App\Http\ViewComposers\MyViewComposer' ); composer 方法还支持 * 通配符,允许将一个 Composer 添加到所有视图: View::composer('*', function ($view) { // });
内容版权声明:除非注明,否则皆为本站原创文章。