我正在使用Laravel 4和刀片模板,并在尝试扩展模板时遇到问题.
在我的布局中我有
@yield('content')
在我的页面中我有
@section('content') Welcome {{ $name }} @stop
哪个工作正常,我创建了另一个与我的第一个非常相似的页面,只想更改覆盖管理内容部分.模板中的其他部分都很好.
所以我扩展我的页面,然后做
@section('content') Hello! @stop
我用$name变量得到一个未定义的通知.
我试过了
@section('content') Hello! @overwrite
和同样的交易,我收到通知错误.
我检查了我的控制器,它使用的是正确的模板.我不是在调用@parent所以我不明白,如何在没有通知错误的情况下覆盖模板中的某个部分?
解决方法
在渲染任何子项之前,刀片布局在树中向上行进到路径或主视图.因此,扩展其他视图的嵌套视图必须始终在父视图之前呈现它们.因此,包含节的父视图将始终在子节点之前呈现.
为了克服您遇到的问题,最好只嵌套不覆盖包含变量的父节的页面,因为父节点内容将始终在子节点之前呈现.
由于不能始终遵守上述理想,或者仍然需要父母部分内容,因此一种好的替代方法是使用视图作曲家.视图作曲家为您提供了在呈现任何特定视图时声明变量的机会.
View::composer(array('pages.admin'),function($view) { $view->with('name',Auth::user()->username); });
另一种选择是使用视图创建者.在实例化视图而不是呈现视图时,创建者会被触发.此方法允许您在呈现视图之前覆盖变量.
View::creator(array('pages.admin'),Auth::user()->username); });