ASCII码 ASCII码

laravel多视图共享数据实例代码

发布于:2022-03-05 10:41:01  栏目:技术文档

页面视图用于显示文档所有内容在整个页面的分布状况和整个文档在每一页上的位置,并可对其进行编辑操作,具有真正的“所见即所得”的显示效果,下面这篇文章主要给大家介绍了关于laravel多视图共享数据的相关资料,需要的朋友可以参考下

目录前言在视图间共享数据视图Composer添加 Composer 到多个视图总结

前言在做项目中,网站前台或者后台有些数据需要在多个视图页面使用,例如用户基本信息数据,菜单展示数据。首先想到的是在每个控制器里传入这些需要的数据,但显然这并不科学。经查视图文档了解,可以使用视图间共享数据和视图Composer解决。

在视图间共享数据有时候我们需要在所有视图之间共享数据片段,这时候可以使用视图工厂的 share 方法,通常,需要在服务提供者的 boot 方法中调用 share 方法,你可以将其添加到 AppServiceProvider 或生成独立的服务提供者来存放它们:

`<?php

namespace App\Providers;

class AppServiceProvider extends ServiceProvider{ /**

  1. * 启动所有应用服务
  2. *
  3. * @return void
  4. */
  5. public function boot()
  6. {
  7. view()->share('name', 'dashuai');
  8. }
  9. /**
  10. * 注册服务提供者
  11. *
  12. * @return void
  13. */
  14. public function register()
  15. {
  16. //
  17. }

}`

在各视图中使用 $name 即可调用。

视图Composer视图Composer 是当视图被渲染时的回调或类方法。如果你有一些数据要在视图每次渲染时都做绑定,可以使用视图 Composer 将逻辑组织到一个单独的地方。

首先要在服务提供者中注册视图 Composer,我们将会使用辅助函数 view 来访问 Illuminate\Contracts\View\Factory 的底层实现,记住,Laravel 不会包含默认的视图 Composer 目录,我们可以按照自己的喜好组织其路径,例如可以创建一个 App\Http\ViewComposers 目录:

`<?php

namespace App\Providers;

use Illuminate\Support\ServiceProvider;

class ComposerServiceProvider extends ServiceProvider{ /**

  1. * 在容器中注册绑定.
  2. *
  3. * @return void
  4. * @author http://laravelacademy.org
  5. */
  6. public function boot()
  7. {
  8. // 使用基于类的composers...
  9. view()->composer(
  10. 'profile', 'App\Http\ViewComposers\ProfileComposer'
  11. );
  12. // 使用基于闭包的composers...
  13. view()->composer('dashboard', function ($view) {
  14. });
  15. }
  16. /**
  17. * 注册服务提供者.
  18. *
  19. * @return void
  20. */
  21. public function register()
  22. {
  23. //
  24. }

}`

如果创建一个新的服务提供者来包含视图 Composer 注册,需要添加该服务提供者到配置文件 config/app.php 的 providers 数组中。

现在我们已经注册了 Composer,每次 profile 视图被渲染时都会执行 ProfileComposer@compose,接下来我们来定义该 Composer 类:

`<?php

namespace App\Http\ViewComposers;

use Illuminate\Contracts\View\View;use Illuminate\Users\Repository as UserRepository;

class ProfileComposer{ /**

  1. * 用户仓库实现.
  2. *
  3. * @var UserRepository
  4. */
  5. protected $users;
  6. /**
  7. * 创建一个新的属性composer.
  8. *
  9. * @param UserRepository $users
  10. * @return void
  11. */
  12. public function __construct(UserRepository $users)
  13. {
  14. // Dependencies automatically resolved by service container...
  15. $this->users = $users;
  16. }
  17. /**
  18. * 绑定数据到视图.
  19. *
  20. * @param View $view
  21. * @return void
  22. */
  23. public function compose(View $view)
  24. {
  25. $view->with('count', $this->users->count());
  26. }

}`

图被渲染前,Composer 类的 compose 方法被调用,同时 Illuminate\Contracts\View\View 被注入该方法,从而可以使用其 with 方法来绑定数据到视图。

添加 Composer 到多个视图你可以传递视图数组作为 composer 方法的第一个参数来一次性将视图 Composer 添加到多个视图:

view()->composer( ['profile', 'dashboard'], 'App\Http\ViewComposers\MyViewComposer' );

composer 方法接受 * 通配符,从而允许将一个 Composer 添加到所有视图:

view()->composer('*', function ($view) { // });

相关推荐
阅读 +