自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Laravel 5 多個視圖共享數(shù)據(jù)的方法

大數(shù)據(jù)
我們都知道模板一般會用到繼承,導(dǎo)航欄就是一個很好的例子,但是導(dǎo)航欄的數(shù)據(jù)如何共享

 

我們都知道模板一般會用到繼承,導(dǎo)航欄就是一個很好的例子,但是導(dǎo)航欄的數(shù)據(jù)如何共享,比如有個導(dǎo)航的文件叫在view/navigation.blade.php
為了簡單一點,文件里只有設(shè)置了一個變量
1
{{ $cqh }}
現(xiàn)在的要求是每個頁面都會用到這個變量,如何共享這個數(shù)據(jù)呢?
 
一般這樣的操作我會在Laravel服務(wù)的boot方法里設(shè)置,下面介紹兩種共享數(shù)據(jù)的方法
 

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

1
2
3
4
public function boot()
{
    View::share('cqh','chenqionghe');
}
這是使用外觀模式,也可以直接使用view()方法,
1
view()->share('cqh', 'chenqionghe');

 

方法二:使用composer方法單獨對這個navigation.blade.php進(jìn)行傳送數(shù)據(jù),方法如下
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 都將會被執(zhí)行。
下面我們來看這個組件怎么定義
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 方法就會被調(diào)用,并且傳入一個 Illuminate\Contracts\View\View 實例。你可以使用 with 方法來把數(shù)據(jù)綁定到 view。
 
 
注意:方法一和方法二其實是有區(qū)別的,方法一是對所有的視圖都傳遞的cqh數(shù)據(jù),而方法二只是對navigation視圖傳遞了cqh數(shù)據(jù)
如果方法二要達(dá)到方法一的效果,可以這樣
1
2
3
4
View::composer('*', function($view)
{
    //
});
這樣就會對所有視圖進(jìn)行傳遞了
 
也可以針對多個視圖指定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'
]);

 

 

責(zé)任編輯:李英杰 來源: 博客園
相關(guān)推薦

2025-01-07 12:58:28

2023-12-20 11:12:39

共享內(nèi)存.NET數(shù)據(jù)共享

2010-10-26 16:43:58

查看Oracle索引

2010-11-15 11:28:21

oracle自動啟動

2021-03-26 05:54:00

C#數(shù)據(jù)方法

2021-06-10 00:13:43

C#隊列數(shù)據(jù)

2020-10-25 08:56:31

數(shù)據(jù)分析數(shù)據(jù)大數(shù)據(jù)

2009-01-11 09:28:00

局域網(wǎng)共享上網(wǎng)

2010-11-09 15:06:52

SQL Server動

2009-04-07 10:45:43

Oracle視圖創(chuàng)建

2022-04-12 09:30:00

共享代碼塊數(shù)據(jù)集數(shù)據(jù)科學(xué)家

2011-07-14 17:50:50

domino數(shù)據(jù)庫

2011-07-05 10:48:41

javascript

2023-07-11 16:01:47

共享數(shù)據(jù)開發(fā)

2010-09-09 15:13:33

SQL更新數(shù)據(jù)

2019-01-16 18:39:24

數(shù)據(jù)開發(fā)模型

2010-05-10 18:30:31

Oracle多表創(chuàng)建

2010-11-16 10:57:18

oracle創(chuàng)建視圖

2010-11-12 11:44:37

SQL Server刪

2010-02-25 13:50:09

Fedora Fire
點贊
收藏

51CTO技術(shù)棧公眾號