Laravel5中怎么实现多个视图共享数据

Laravel 5中怎么实现多个视图共享数据,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

企业建站必须是能够以充分展现企业形象为主要目的,是企业文化与产品对外扩展宣传的重要窗口,一个合格的网站不仅仅能为公司带来巨大的互联网上的收集和信息发布平台,成都创新互联公司面向各种领域:办公窗帘成都网站设计成都全网营销解决方案、网站设计等建站排名服务。


1

{{ $cqh }}

现在的要求是每个页面都会用到这个变量,如何共享这个数据呢?

一般这样的操作我会在Laravel服务的boot方法里设置,下面介绍两种共享数据的方法

方法一:使用View:share方法,如CqhServiceProvider里

1

2

3

4

public function boot()

{

    View::share('cqh','chenqionghe');

}

这是使用外观模式,也可以直接使用view()方法,

1

view()->share('cqh', 'chenqionghe');

方法二:使用composer方法单独对这个navigation.blade.php进行传送数据,方法如下

1

2

3

4

5

6

public function boot()

{

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

        $view->with('cqh','chenqionghe');

    });

}

以上是使用闭包的形式来完成这个操作,其实这和路由一样,也可以用类来代替,Laravel里叫组件,方法如下

1

2

3

4

public function boot()

{

    View::composer('navigation', 'App\Http\ViewComposers\MyViewComposer');

}

上面这样就是注册了视图组件,并且在每次 navigation视图渲染的时候,MyViewComposer@compose 都将会被执行。

下面我们来看这个组件怎么定义

1

2

3

4

5

6

7

8

9

<?php namespace App\Http\ViewComposers;

use Illuminate\Contracts\View\View;

class MyViewComposer

{

    public function compose(View $view)

    {

        $view->with('cqh','chenqionghe');

    }

}

在视图被渲染之前,视图组件的 compose 方法就会被调用,并且传入一个 Illuminate\Contracts\View\View 实例。你可以使用 with 方法来把数据绑定到 view。

注意:方法一和方法二其实是有区别的,方法一是对所有的视图都传递的cqh数据,而方法二只是对navigation视图传递了cqh数据

如果方法二要达到方法一的效果,可以这样

1

2

3

4

View::composer('*', function($view)

{

    //

});

这样就会对所有视图进行传递了

也可以针对多个视图指定MyViewComposer组件

1

View::composer(['navigation', 'footer'], 'App\Http\ViewComposers\MyViewComposer');

也可以使用 composers 方法来同时定义一群视图组件

1

2

3

4

5

View::composers([

    'App\Http\ViewComposers\AdminComposer' => ['admin.index', 'admin.profile'],

    'App\Http\ViewComposers\UserComposer' => 'user',

    'App\Http\ViewComposers\ProductComposer' => 'product'

]);

关于Laravel 5中怎么实现多个视图共享数据问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注创新互联行业资讯频道了解更多相关知识。

本文题目:Laravel5中怎么实现多个视图共享数据
浏览地址:https://www.cdcxhl.com/article4/josdoe.html

成都网站建设公司_创新互联,为您提供外贸建站响应式网站用户体验静态网站做网站域名注册

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都定制网站网页设计