亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Laravel向公共模板賦值方法總結(jié)

 更新時(shí)間:2019年06月25日 08:37:55   投稿:laozhang  
在本篇文章里小編給大家整理了關(guān)于Laravel向公共模板賦值方法以及相關(guān)知識(shí)點(diǎn)總結(jié),有興趣的朋友們學(xué)習(xí)下。

開(kāi)發(fā)過(guò)程中許多時(shí)候都會(huì)向公共模板賦值,比如頂部導(dǎo)航欄,頁(yè)面底部等等,不可能在每個(gè)控制器中都賦值一遍。

Laravel 中解決辦法如下: 修改

App\Providers\AppServiceProvider

在boot方法中添加

View()->composer('common.header',function ($view){ //common.header 對(duì)應(yīng)Blade模板 $view->with('key', 'value'); });

也可以向所有模板中賦值

View()->share('key', 'value');

view composers 與視圖有關(guān),用在一個(gè)service provider 的boot()函數(shù)里,就是讓一個(gè)view加載的時(shí)候,由于view composer的作用,去調(diào)用某個(gè)函數(shù)傳個(gè)參啊啥的。

1,創(chuàng)建service provider

php artisan make:provider ComposerServiceProvider

再把ComposerServiceProvider加到config/app.php里面

2,寫(xiě)view composer

public function boot()  {    view()->composer(      'app', //模板名      'App\Http\ViewComposers\MovieComposer' //方法名或者類(lèi)中的方法    );  }

意思是一旦加載app.blade.php,就執(zhí)行App\Http\ViewComposers\MovieComposer里的composer函數(shù)(這里之所以執(zhí)行composer函數(shù)是默認(rèn)的),如果你想換一個(gè)就

view()->composer('app','App\Http\ViewComposers\MovieComposer@foobar'); //自己定義的方法

這里就執(zhí)行foobar函數(shù)了

App\Http\ViewComposers\MovieComposer.php里這么寫(xiě)

<?phpnamespace App\Http\ViewComposers;use Illuminate\View\View;//**記得引入這個(gè)啊(因?yàn)樵赾omposer函數(shù)參數(shù)里使用了View類(lèi))**class MovieComposer{  public $movieList = [];  public function __construct()  {    $this->movieList = [      'Shawshank redemption',      'Forrest Gump',    ];  }  public function compose(View $view)  {    $view->with('latestMovie');  }}

3,其他 當(dāng)所有模板都要,用*正則表達(dá)式

view()->composer('*', function (View $view) {  //logic goes here});

想要指定多個(gè)view使用,用數(shù)組包起來(lái)

view()->composer(['nav', 'footer'],'App\Http\ViewComposers\MovieComposer');或者 view()->composer(['admin.admin'], function ($view){      $column = $this->object_array(DB::table('column')->get());      foreach($column as $k=>$v){        $chid = explode(',',$v['childid']);        foreach($chid as $value){          $column[$k]['chname'][] = $this->object_array(DB::table('column_child')->where('id',$value)->first());        }      }      $view->with('columns',$column);    });

相關(guān)文章

最新評(píng)論