我正在使用Laravel 4和刀片模板,并在尝试扩展模板时遇到问题.
在我的布局中我有
@yield('content')
@section('content')
Welcome {{ $name }}
@stop
哪个工作正常,我创建了另一个与我的第一个非常相似的页面,只想更改覆盖管理内容部分.模板中的其他部分都很好.
所以我扩展我的页面,然后做
@section('content')
Hello!
@stop
我试过了
@section('content')
Hello!
@overwrite
和同样的交易,我收到通知错误.
我检查了我的控制器,它使用的是正确的模板.我不是在调用@parent所以我不明白,如何在没有通知错误的情况下覆盖模板中的某个部分?
解决方法:
在渲染任何子项之前,刀片布局在树中向上行进到路径或主视图.因此,扩展其他视图的嵌套视图必须始终在父视图之前呈现它们.因此,包含节的父视图将始终在子节点之前呈现.
为了克服您遇到的问题,最好只嵌套不覆盖包含变量的父节的页面,因为父节点内容将始终在子节点之前呈现.
由于不能始终遵守上述理想,或者仍然需要父母部分内容,因此一种好的替代方法是使用视图作曲家.视图作曲家为您提供了在呈现任何特定视图时声明变量的机会.
View::composer(array('pages.admin'), function($view)
{
$view->with('name', Auth::user()->username);
});
另一种选择是使用视图创建者.在实例化视图而不是呈现视图时,创建者会被触发.此方法允许您在呈现视图之前覆盖变量.
View::creator(array('pages.admin'), function($view)
{
$view->with('name', Auth::user()->username);
});
您可以在文档here中阅读有关这些方法的更多信息.(或者,对于Laravel 5文档,请参阅here.)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。