laravel5.5框架中视图间如何共享数据?

laravel框架中视图间共享数据有两种,一种是用视图门面share()方法实现,另一种是用视图门面composer() 方法实现,那么,两种方法的实现究竟是怎样的呢?让我们来看一看接下来的文章内容。

首先,需要注意的一点是:都是使用 View 门面来访问 Illuminate\Contracts\View\Factory 的底层实现

视图门面share()方法

有时需要在所有视图之间共享数据片段,这时候可以使用视图门面的 share 方法。

1,一般情况下,我会在app\http\Controllers\xx下创建一个基础控制器 ,

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<?php

namespaceApp\Http\Controllers\ExtMan;

useIlluminate\Routing\Controller;

classBaseController extendsController

{

    publicfunction__construct(\Auth $auth)

    {

        $this->initViewShare();   

    }

    publicfunctioninitViewShare()

    {

        view()->share('action_name',get_action_name());

     }

}

{{ $action_name}}

get_action_name() 是自定义的一个函数。

 

tips:
创建 app\Helpers\ , 的autoload引入

1

2

3

"files":[

    "app/Helpers/"

]

运行 composer dump-autoload 会自动加载

2,在 AppServiceProvider 服务提供器(或者新建提供器) 的boot方法中调用share()

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

<?php

namespaceApp\Providers;

useView;

classAppServiceProvider extendsServiceProvider

{

    publicfunctionboot()

    {

        View::share('key''value');

        view()->share('name','共享数据片段');

    }

}

视图门面composer()方法

视图合成器是当视图被渲染时的回调函数或类方法 ,如果你每次渲染视图时都要绑定视图的数据,比如用户登陆信息。可以使用composer() 将逻辑组织到一个单独的地方。
本例中,我们将在AppServiceProvider服务提供器中注册视图合成器,
提供器代码如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

<?php

namespaceApp\Providers;

#useIlluminate\Support\Facades\View;

useIlluminate\Support\ServiceProvider;

classAppServiceProvider extendsServiceProvider

{

    publicfunctionboot()

    {

        view()->composer(

            ['extman.*'], 'App\Http\ViewComposers\AuthComposer'

        );

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

            $view->with('user',array('name'=>'test','avatar'=>'/path/to/'));

        });

    }

other code

}

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

到此已经注册了视图合成器,每次渲染 extman目录下所有视图时都会执行 AuthComposer@compose 方法。
定义视图合成器类 App\Http\ViewComposers\AuthComposer.php

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<?php

namespaceApp\Http\ViewComposers;

useIlluminate\View\View;

useIlluminate\Repositories\UserRepository;

classAuthComposer

{

    protected$users;

    publicfunction__construct(UserRepository $users)

    {

        $this->users = $users;

    }

    publicfunctioncompose(View $view)

    {

        $user_info= \Auth::user();

        $view->with('motto'$user_info);

        $view->with('count'$this->users->count());

    }

}

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

所有的视图合成器都会通过 服务容器 进行解析,所以你可以在视图合成器的构造函数中类型提示需要注入的依赖项。

THE END